



# T113x

## User Manual

Revision 1.1

November 29, 2023

## Revision History

| Revision | Date              | Author  | Description                                                                |
|----------|-------------------|---------|----------------------------------------------------------------------------|
| 1.0      | June 16, 2023     | KPA0570 | Initial release version                                                    |
| 1.1      | November 29, 2023 | KPA0570 | <b>Chapter 4 Video and Graphics</b><br>Update the features in section 4.1. |

# Contents

|                                      |    |
|--------------------------------------|----|
| Revision History .....               | i  |
| Contents .....                       | ii |
| 1 About This Document .....          | 1  |
| 1.1 Purpose and Scope .....          | 1  |
| 1.2 Intended Audience .....          | 1  |
| 1.3 Revision Number Definition ..... | 1  |
| 1.4 Symbol Conventions.....          | 1  |
| 1.4.1 Symbol Conventions.....        | 1  |
| 1.4.2 Table Content Conventions..... | 2  |
| 1.4.3 Reset Value Conventions .....  | 2  |
| 1.4.4 Register Attributes .....      | 2  |
| 1.4.5 Numerical System .....         | 2  |
| Contents .....                       | 4  |
| Figures.....                         | 5  |
| Tables .....                         | 6  |
| 2 Product Description .....          | 7  |
| 2.1 Overview .....                   | 7  |
| 2.2 Device Difference .....          | 7  |
| 2.3 Features .....                   | 7  |
| 2.3.1 CPU Architecture.....          | 7  |
| 2.3.2 DSP Architecture .....         | 8  |
| 2.3.3 Memory SubSystem .....         | 8  |
| 2.3.4 Video Engine .....             | 9  |
| 2.3.5 Video and Graphics .....       | 9  |
| 2.3.6 Video Output.....              | 11 |
| 2.3.7 Video Input.....               | 12 |
| 2.3.8 System Peripherals.....        | 13 |
| 2.3.9 Audio Interfaces .....         | 16 |
| 2.3.10 Security System.....          | 18 |
| 2.3.11 External Peripherals .....    | 20 |

|                                                         |     |
|---------------------------------------------------------|-----|
| 2.3.12 Package .....                                    | 26  |
| 2.4 Block Diagram .....                                 | 27  |
| Contents.....                                           | 30  |
| Figures.....                                            | 33  |
| Tables .....                                            | 35  |
| 3 System.....                                           | 36  |
| 3.1 Memory Mapping.....                                 | 36  |
| 3.2 CPU Configuration.....                              | 41  |
| 3.2.1 Overview .....                                    | 41  |
| 3.2.2 Functional Descriptions.....                      | 41  |
| 3.2.3 Cluster 0 Configuration Register List.....        | 43  |
| 3.2.4 Cluster 0 Configuration Register Description..... | 44  |
| 3.2.5 CPU Subsystem Control Register List .....         | 52  |
| 3.2.6 CPU Subsystem Control Register Description .....  | 53  |
| 3.3 Clock Controller Unit (CCU).....                    | 57  |
| 3.3.1 Overview .....                                    | 57  |
| 3.3.2 Block Diagram .....                               | 57  |
| 3.3.3 Functional Description .....                      | 58  |
| 3.3.4 Programming Guidelines.....                       | 63  |
| 3.3.5 Register List .....                               | 69  |
| 3.3.6 Register Description .....                        | 73  |
| 3.4 BROM System.....                                    | 160 |
| 3.4.1 Overview .....                                    | 160 |
| 3.4.2 Functional Description .....                      | 160 |
| 3.5 System Configuration.....                           | 171 |
| 3.5.1 Overview .....                                    | 171 |
| 3.5.2 Register List .....                               | 171 |
| 3.5.3 Register Description .....                        | 171 |
| 3.6 RISC-V System .....                                 | 179 |
| 3.6.1 Overview .....                                    | 179 |
| 3.6.2 Block Diagram .....                               | 179 |
| 3.6.3 Register List .....                               | 180 |
| 3.6.4 Register Description .....                        | 182 |

|                                                       |     |
|-------------------------------------------------------|-----|
| 3.7 Timer .....                                       | 196 |
| 3.7.1 Overview .....                                  | 196 |
| 3.7.2 Block Diagram .....                             | 197 |
| 3.7.3 Functional Description .....                    | 197 |
| 3.7.4 Programming Guidelines.....                     | 201 |
| 3.7.5 Register List.....                              | 202 |
| 3.7.6 Register Description .....                      | 203 |
| 3.8 High Speed Timer .....                            | 215 |
| 3.8.1 Overview .....                                  | 215 |
| 3.8.2 Block Diagram .....                             | 215 |
| 3.8.3 Functional Description .....                    | 215 |
| 3.8.4 Programming Guidelines.....                     | 219 |
| 3.8.5 Register List.....                              | 219 |
| 3.8.6 Register Description .....                      | 220 |
| 3.9 Generic Interrupt Controller (GIC) .....          | 227 |
| 3.9.1 Overview .....                                  | 227 |
| 3.9.2 Functional Description .....                    | 227 |
| 3.10 Platform-Level Interrupt Controller (PLIC) ..... | 235 |
| 3.10.1 Overview .....                                 | 235 |
| 3.10.2 Functional Description .....                   | 235 |
| 3.10.3 Register List.....                             | 242 |
| 3.10.4 Register Description .....                     | 242 |
| 3.11 Direct Memory Access Controller (DMAC) .....     | 246 |
| 3.11.1 Overview .....                                 | 246 |
| 3.11.2 Block Diagram .....                            | 246 |
| 3.11.3 Functional Description .....                   | 247 |
| 3.11.4 Programming Guidelines.....                    | 256 |
| 3.11.5 Register List.....                             | 259 |
| 3.11.6 Register Description .....                     | 260 |
| 3.12 Thermal Sensor Controller (THS) .....            | 280 |
| 3.12.1 Overview .....                                 | 280 |
| 3.12.2 Block Diagram .....                            | 280 |
| 3.12.3 Functional Description .....                   | 280 |

|                                     |     |
|-------------------------------------|-----|
| 3.12.4 Programming Guidelines.....  | 282 |
| 3.12.5 Register List.....           | 284 |
| 3.12.6 Register Description.....    | 284 |
| 3.13 IOMMU .....                    | 290 |
| 3.13.1 Overview .....               | 290 |
| 3.13.2 Block Diagram .....          | 290 |
| 3.13.3 Functional Description ..... | 291 |
| 3.13.4 Programming Guidelines.....  | 301 |
| 3.13.5 Register List.....           | 302 |
| 3.13.6 Register Description.....    | 306 |
| 3.14 Message Box .....              | 376 |
| 3.14.1 Overview .....               | 376 |
| 3.14.2 Block Diagram .....          | 376 |
| 3.14.3 Functional Description ..... | 377 |
| 3.14.4 Programming Guidelines.....  | 378 |
| 3.14.5 Register List.....           | 379 |
| 3.14.6 Register Description .....   | 380 |
| 3.15 Spinlock .....                 | 386 |
| 3.15.1 Overview .....               | 386 |
| 3.15.2 Block Diagram .....          | 386 |
| 3.15.3 Functional Description ..... | 386 |
| 3.15.4 Programming Guidelines.....  | 388 |
| 3.15.5 Register List.....           | 391 |
| 3.15.6 Register Description .....   | 391 |
| 3.16 RTC .....                      | 395 |
| 3.16.1 Overview .....               | 395 |
| 3.16.2 Block Diagram .....          | 395 |
| 3.16.3 Functional Description ..... | 396 |
| 3.16.4 Programming Guidelines.....  | 400 |
| 3.16.5 Register List.....           | 402 |
| 3.16.6 Register Description .....   | 403 |
| Contents.....                       | 415 |
| Figures.....                        | 416 |

|                |                                    |     |
|----------------|------------------------------------|-----|
| 4              | Video and Graphics .....           | 417 |
| 4.1            | DE .....                           | 417 |
| 4.2            | DI .....                           | 419 |
| 4.3            | G2D .....                          | 420 |
| 4.4            | Video Decoding .....               | 421 |
| 4.4.1          | Overview .....                     | 421 |
| 4.4.2          | Block Diagram .....                | 422 |
| 4.5            | Video Encoding .....               | 423 |
| 4.5.1          | Overview .....                     | 423 |
| 4.5.2          | Block Diagram .....                | 423 |
| Contents ..... | 425                                |     |
| Figures .....  | 426                                |     |
| Tables .....   | 427                                |     |
| 5              | Video Output Interfaces .....      | 428 |
| 5.1            | TCON LCD .....                     | 428 |
| 5.1.1          | Overview .....                     | 428 |
| 5.1.2          | Block Diagram .....                | 429 |
| 5.1.3          | Functional Description .....       | 429 |
| 5.1.4          | Programming Guidelines .....       | 441 |
| 5.1.5          | Register List .....                | 448 |
| 5.1.6          | Register Description .....         | 450 |
| 5.2            | TCON TV .....                      | 483 |
| 5.2.1          | Overview .....                     | 483 |
| 5.2.2          | Functional Description .....       | 483 |
| 5.2.3          | Register List .....                | 483 |
| 5.2.4          | Register Description .....         | 484 |
| 5.3            | TV Encoder .....                   | 496 |
| 5.3.1          | Overview .....                     | 496 |
| 5.3.2          | Block Diagram .....                | 496 |
| 5.3.3          | Functional Description .....       | 496 |
| 5.3.4          | Programming Guidelines .....       | 498 |
| 5.3.5          | Register List .....                | 499 |
| 5.3.6          | TVE_TOP Register Description ..... | 501 |

|                                           |     |
|-------------------------------------------|-----|
| 5.3.7 TVE Register Description .....      | 505 |
| 5.4 MIPI DSI .....                        | 525 |
| 5.4.1 Overview .....                      | 525 |
| Contents .....                            | 526 |
| Figures .....                             | 527 |
| Tables .....                              | 528 |
| 6 Video Input Interfaces .....            | 530 |
| 6.1 CSIC .....                            | 530 |
| 6.1.1 Overview .....                      | 530 |
| 6.1.2 Block Diagram .....                 | 530 |
| 6.1.3 Functional Description .....        | 531 |
| 6.1.4 Register List .....                 | 533 |
| 6.1.5 CCU Register Description .....      | 537 |
| 6.1.6 CSIC Top Register Description ..... | 538 |
| 6.1.7 Parser Register Description .....   | 543 |
| 6.1.8 CSIC DMA Register Description ..... | 564 |
| 6.2 TV Decoder .....                      | 579 |
| 6.2.1 Overview .....                      | 579 |
| 6.2.2 Block Diagram .....                 | 579 |
| 6.2.3 Functional Description .....        | 579 |
| 6.2.4 Register List .....                 | 580 |
| 6.2.5 Register Description .....          | 582 |
| Contents .....                            | 618 |
| Figures .....                             | 619 |
| Tables .....                              | 620 |
| 7 Memory .....                            | 621 |
| 7.1 SDRAM Controller (DRAMC) .....        | 621 |
| 7.2 SD/MMC Host Controller (SMHC) .....   | 622 |
| 7.2.1 Overview .....                      | 622 |
| 7.2.2 Block Diagram .....                 | 622 |
| 7.2.3 Functional Description .....        | 623 |
| 7.2.4 Programming Guidelines .....        | 636 |
| 7.2.5 Register List .....                 | 641 |

|                                    |     |
|------------------------------------|-----|
| 7.2.6 Register Description .....   | 643 |
| Contents.....                      | 674 |
| Figures.....                       | 675 |
| Tables.....                        | 677 |
| 8 Audio.....                       | 678 |
| 8.1 I2S/PCM.....                   | 678 |
| 8.1.1 Overview .....               | 678 |
| 8.1.2 Block Diagram .....          | 678 |
| 8.1.3 Functional Description ..... | 680 |
| 8.1.4 Programming Guidelines.....  | 686 |
| 8.1.5 Register List.....           | 688 |
| 8.1.6 Register Description .....   | 690 |
| 8.2 DMIC.....                      | 738 |
| 8.2.1 Overview .....               | 738 |
| 8.2.2 Block Diagram .....          | 738 |
| 8.2.3 Functional Description ..... | 738 |
| 8.2.4 Register List.....           | 741 |
| 8.2.5 Register Description .....   | 741 |
| 8.3 OWA .....                      | 756 |
| 8.3.1 Overview .....               | 756 |
| 8.3.2 Block Diagram .....          | 757 |
| 8.3.3 Functional Description ..... | 757 |
| 8.3.4 Register List.....           | 762 |
| 8.3.5 Register Description .....   | 762 |
| 8.4 Audio Codec .....              | 772 |
| 8.4.1 Overview .....               | 772 |
| 8.4.2 Block Diagram .....          | 773 |
| 8.4.3 Functional Description ..... | 773 |
| 8.4.4 Programming Guidelines.....  | 781 |
| 8.4.5 Register List.....           | 782 |
| 8.4.6 Register Description .....   | 787 |
| Contents.....                      | 861 |
| Figures.....                       | 864 |

|                                    |      |
|------------------------------------|------|
| Tables .....                       | 868  |
| 9 Interfaces .....                 | 870  |
| 9.1 TWI .....                      | 870  |
| 9.1.1 Overview .....               | 870  |
| 9.1.2 Block Diagram .....          | 870  |
| 9.1.3 Functional Description ..... | 872  |
| 9.1.4 Programming Guidelines.....  | 878  |
| 9.1.5 Register List.....           | 881  |
| 9.1.6 Register Description .....   | 882  |
| 9.2 UART.....                      | 897  |
| 9.2.1 Overview .....               | 897  |
| 9.2.2 Block Diagram .....          | 897  |
| 9.2.3 Functional Description ..... | 898  |
| 9.2.4 Programming Guidelines.....  | 904  |
| 9.2.5 Register List.....           | 907  |
| 9.2.6 Register Description .....   | 909  |
| 9.3 SPI.....                       | 938  |
| 9.3.1 Overview.....                | 938  |
| 9.3.2 Block Diagram .....          | 938  |
| 9.3.3 Functional Description ..... | 940  |
| 9.3.4 Programming Guidelines.....  | 948  |
| 9.3.5 Register List.....           | 951  |
| 9.3.6 Register Description .....   | 952  |
| 9.4 SPI_DBI.....                   | 973  |
| 9.4.1 Overview .....               | 973  |
| 9.4.2 Block Diagram .....          | 973  |
| 9.4.3 Functional Description ..... | 975  |
| 9.4.4 Programming Guidelines.....  | 995  |
| 9.4.5 Register List.....           | 1003 |
| 9.4.6 Register Description .....   | 1004 |
| 9.5 USB2.0 DRD .....               | 1036 |
| 9.5.1 Overview .....               | 1036 |
| 9.5.2 Block Diagram .....          | 1037 |

|                                       |      |
|---------------------------------------|------|
| 9.5.3 Functional Description .....    | 1037 |
| 9.6 USB2.0 HOST .....                 | 1039 |
| 9.6.1 Overview .....                  | 1039 |
| 9.6.2 Block Diagram .....             | 1039 |
| 9.6.3 Functional Description .....    | 1040 |
| 9.6.4 Register List .....             | 1040 |
| 9.6.5 EHCI Register Description ..... | 1042 |
| 9.6.6 OHCI Register Description ..... | 1059 |
| 9.7 GPIO .....                        | 1081 |
| 9.7.1 Overview .....                  | 1081 |
| 9.7.2 Block Diagram .....             | 1081 |
| 9.7.3 Functional Description .....    | 1082 |
| 9.7.4 Register List .....             | 1090 |
| 9.7.5 Register Description .....      | 1092 |
| 9.8 GPADC .....                       | 1183 |
| 9.8.1 Overview .....                  | 1183 |
| 9.8.2 Block Diagram .....             | 1183 |
| 9.8.3 Functional Description .....    | 1184 |
| 9.8.4 Programming Guidelines .....    | 1185 |
| 9.8.5 Register List .....             | 1187 |
| 9.8.6 Register Description .....      | 1188 |
| 9.9 TPADC .....                       | 1196 |
| 9.9.1 Overview .....                  | 1196 |
| 9.9.2 Functional Description .....    | 1196 |
| 9.9.3 Register List .....             | 1202 |
| 9.9.4 Register Description .....      | 1203 |
| 9.10 PWM .....                        | 1211 |
| 9.10.1 Overview .....                 | 1211 |
| 9.10.2 Block Diagram .....            | 1211 |
| 9.10.3 Functional Description .....   | 1212 |
| 9.10.4 Programming Guidelines .....   | 1222 |
| 9.10.5 Register List .....            | 1223 |
| 9.10.6 Register Description .....     | 1225 |

|                                     |      |
|-------------------------------------|------|
| 9.11 LEDC .....                     | 1252 |
| 9.11.1 Overview .....               | 1252 |
| 9.11.2 Block Diagram .....          | 1252 |
| 9.11.3 Functional Description ..... | 1253 |
| 9.11.4 Programming Guidelines.....  | 1257 |
| 9.11.5 Register List.....           | 1262 |
| 9.11.6 Register Description .....   | 1262 |
| 9.12 EMAC.....                      | 1273 |
| 9.12.1 Overview .....               | 1273 |
| 9.12.2 Block Diagram .....          | 1273 |
| 9.12.3 Functional Description ..... | 1274 |
| 9.12.4 Programming Guidelines.....  | 1281 |
| 9.12.5 Register List.....           | 1282 |
| 9.12.6 Register Description .....   | 1283 |
| 9.13 CIR Receiver .....             | 1302 |
| 9.13.1 Overview .....               | 1302 |
| 9.13.2 Block Diagram .....          | 1302 |
| 9.13.3 Functional Description ..... | 1303 |
| 9.13.4 Programming Guidelines.....  | 1307 |
| 9.13.5 Register List.....           | 1308 |
| 9.13.6 Register Description .....   | 1308 |
| 9.14 CIR Transmitter .....          | 1314 |
| 9.14.1 Overview .....               | 1314 |
| 9.14.2 Block Diagram .....          | 1314 |
| 9.14.3 Functional Description ..... | 1315 |
| 9.14.4 Programming Guidelines.....  | 1317 |
| 9.14.5 Register List.....           | 1318 |
| 9.14.6 Register Description .....   | 1318 |
| 9.15 CAN .....                      | 1326 |
| Contents.....                       | 1327 |
| Figures.....                        | 1328 |
| 10 Security System.....             | 1329 |
| 10.1 Crypto Engine .....            | 1329 |

|                                     |      |
|-------------------------------------|------|
| 10.1.1 Overview .....               | 1329 |
| 10.1.2 Block Diagram .....          | 1330 |
| 10.1.3 Functional Description ..... | 1330 |
| 10.1.4 Programming Guidelines.....  | 1350 |
| 10.1.5 Register List.....           | 1353 |
| 10.1.6 Register Description.....    | 1354 |
| 10.2 Security ID .....              | 1358 |
| Appendix: Glossary .....            | 1359 |

# 1 About This Document

## 1.1 Purpose and Scope

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

## 1.2 Intended Audience

The document is intended for:

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

## 1.3 Revision Number Definition

**Revision 1.00-1.0x**

This document is released based on the verifications in small volume production. The information in this document may be modified, calibrated and supplemented hereafter.

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

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

## 1.4 Symbol Conventions

### 1.4.1 Symbol Conventions

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

| Symbol                                                                                             | Description                                                                            |
|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|
|  <b>WARNING</b> | Indicates potential risk of injury or death exists if the instructions are not obeyed. |

| Symbol                                                                                    | Description                                                                                                                                        |
|-------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|  CAUTION | Indicates potential risk of equipment damage, data loss, performance degradation, or unexpected results exists if the instructions are not obeyed. |
|  NOTE    | Provides additional information to emphasize or supplement important points of the main text.                                                      |

#### 1.4.2 Table Content Conventions

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

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

#### 1.4.3 Reset Value Conventions

In the register definition tables:

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

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

#### 1.4.4 Register Attributes

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

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

#### 1.4.5 Numerical System

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

| Type          | Symbol | Value         |
|---------------|--------|---------------|
| Data capacity | 1 K    | 1024          |
|               | 1 M    | 1,048,576     |
|               | 1 G    | 1,073,741,824 |

| Type                 | Symbol | Value         |
|----------------------|--------|---------------|
| Frequency, data rate | 1 k    | 1000          |
|                      | 1 M    | 1,000,000     |
|                      | 1 G    | 1,000,000,000 |

The expressions of addresses and data are described as follows.

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

# Contents

|                                   |    |
|-----------------------------------|----|
| 2.1 Overview .....                | 7  |
| 2.2 Device Difference .....       | 7  |
| 2.3 Features .....                | 7  |
| 2.3.1 CPU Architecture .....      | 7  |
| 2.3.2 DSP Architecture .....      | 8  |
| 2.3.3 Memory SubSystem .....      | 8  |
| 2.3.4 Video Engine .....          | 9  |
| 2.3.5 Video and Graphics .....    | 9  |
| 2.3.6 Video Output .....          | 11 |
| 2.3.7 Video Input .....           | 12 |
| 2.3.8 System Peripherals .....    | 13 |
| 2.3.9 Audio Interfaces .....      | 16 |
| 2.3.10 Security System .....      | 18 |
| 2.3.11 External Peripherals ..... | 20 |
| 2.3.12 Package .....              | 26 |
| 2.4 Block Diagram .....           | 27 |

## Figures

|                                             |    |
|---------------------------------------------|----|
| Figure 2-1 T113x System Block Diagram ..... | 27 |
| Figure 2-2 Car MP5 Solution .....           | 28 |
| Figure 2-3 Car Instrument Solution.....     | 28 |
| Figure 2-4 HMI Solution .....               | 29 |
| Figure 2-5 PLC Solution .....               | 29 |

# Tables

|                                            |   |
|--------------------------------------------|---|
| Table 2-1 Device Feature Differences ..... | 7 |
|--------------------------------------------|---|

## 2 Product Description

### 2.1 Overview

T113x is an advanced application processor. It integrates a dual-core Cortex™-A7 CPU, a RISC-V CPU, and a HiFi4 DSP to provide the high efficient computing power. T113x supports full format decoding such as H.265, H.264, MPEG-1/2/4, JPEG, VC1, and so on. The independent hardware encoder can encode in JPEG or MJPEG. Integrated multi ADCs/DACs and I2S/PCM/DMIC/OWA audio interfaces can provide the perfect voice interaction solution. T113x comes with extensive connectivity to facilitate product expansion, such as USB SDIO, EMAC, TWI, UART, SPI, PWM, GPADC, IR TX&RX, and so on.

### 2.2 Device Difference

T113x is configured with different sets of features in different devices. The following table shows the feature differences across different devices.

Table 2-1 Device Feature Differences

| Feature  | T113-S2                 | T113-S3                  | T113M3010DC0             | T113M4020DC0             | T113M4030DC0             |
|----------|-------------------------|--------------------------|--------------------------|--------------------------|--------------------------|
| RISC-V   | Not Support             | Not Support              | Support                  | Support                  | Support                  |
| DSP      | Not Support             | Support                  | Support                  | Support                  | Support                  |
| DDR      | SIP DDR2 64MB           | SIP DDR3<br>128 MB       | SIP DDR3<br>128 MB       | SIP DDR3<br>256 MB       | SIP DDR3<br>256 MB       |
| MIPI DSI | Up to<br>1280x720@60fps | Up to<br>1920x1200@60fps | Up to<br>1920x1200@60fps | Up to<br>1920x1200@60fps | Up to<br>1920x1200@60fps |

### 2.3 Features

#### 2.3.1 CPU Architecture

- Dual-core ARM Cortex™-A7
  - 32 KB L1 I-cache + 32 KB L1 D-cache + NEON SIMD + Thumb-2/FPU + 256 KB L2 cache
- RISC-V CPU
  - 32 KB I-cache + 32 KB D-cache

### 2.3.2 DSP Architecture

- HiFi4
- 32 KB L1 I-cache and 32 KB L1 D-cache
- 64 KB I-ram and 64 KB D-ram

### 2.3.3 Memory SubSystem

#### 2.3.3.1 Boot ROM (BROM)

- On-chip memory
- Supports system boot from the following devices:
  - SD card
  - eMMC
  - SPI NOR Flash
  - SPI NAND Flash
- Supports mandatory upgrade process through USB and SD card
- Supports GPIO pin and eFuse module to select the boot media type
- Supports normal booting and secure booting
- Secure BROM loads only certified firmware
- Secure BROM ensures that the Secure Boot is in a trusted environment

#### 2.3.3.2 SDRAM

- Embedded with DDR

#### 2.3.3.3 SMHC

- Three SD/MMC host controller (SMHC) interfaces
- The SMHC0 controls the devices that comply with the protocol Secure Digital Memory (SD mem-version 3.0)
- The SMHC1 controls the device that complies with the protocol Secure Digital I/O (SDIO-version 3.0)

- The SMHC2 controls the device that complies with the protocol Multimedia Card (eMMC-version 5.0)
- Maximum performance:
  - SDR mode 150 MHz@1.8 V IO pad
  - DDR mode 50 MHz@1.8 V IO pad
  - DDR mode 50 MHz@3.3 V IO pad
- Supports 1-bit or 4-bit data width
- Supports block size of 1 to 65535 bytes
- Internal 1024-Bytes RX FIFO and 1024-Bytes TX FIFO
- Supports card insertion and removal interrupt
- Supports hardware CRC generation and error detection
- Supports descriptor-based internal DMA controller

### 2.3.4 Video Engine

- Video decoding
  - H.265 MP@L4.1 up to 1080p@60fps
  - H.264 BP/MP/HP@L4.2 up to 1080p@60fps
  - H.263 BP up to 1080p@60fps
  - MPEG-4 SP/ASP L5.0 up to 1080p@60fps
  - MPEG-2 MP/HL up to 1080p@60fps
  - MPEG-1 MP/HL up to 1080p@60fps
  - JPEG/Xvid/Sorenson Spark up to 1080p@60fps
  - MJPEG up to 1080p@30fps
- Video encoding
  - JPEG/MJPEG up to 1080p@60fps
  - Supports input picture scaler up/down

### 2.3.5 Video and Graphics

#### 2.3.5.1 Display Engine (DE)

- Output size up to 2048 x 2048

- Supports two alpha blending channels for main display and one channel for aux display
- Supports four overlay layers in each channel, and has an independent scaler
- Supports porter-duff compatible blending operation
- Supports LBC buffer decoder
- Supports dither output to TCON
- Supports input format Semi-planar YUV422/YUV420/YUV411 and Planar YUV422/YUV420/YUV411, ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555/RGB565/palette
- Supports SmartColor2.0 for excellent display experience
  - Adaptive detail/edge enhancement
    - Adaptive color enhancement
    - Adaptive contrast enhancement and fresh tone rectify
- Supports write back for aux display

### 2.3.5.2 De-interlacer (DI)

- Supports YUV420 (Planar/NV12/NV21) and YUV422 (Planar/NV16/NV61) data format
- Supports video resolution from 32 x 32 to 2048 x 1280 pixel
- Supports Inter-field interpolation/motion adaptive de-interlace method
- Performance: module clock 600M for 1080p@60Hz YUV420

### 2.3.5.3 Graphic 2D (G2D)

- Supports layer size up to 2048 x 2048 pixels
- Supports pre-multiply alpha image data
- Supports color key
- Supports two pipes Porter-Duff alpha blending
- Supports multiple video formats 4:2:0, 4:2:2, 4:1:1 and multiple pixel formats (8/16/24/32 bits graphics layer)
- Supports memory scan order option
- Supports any format convert function
- Supports 1/16x to 32x resize ratio

- Supports 32-phase 8-tap horizontal anti-alias filter and 32-phase 4-tap vertical anti-alias filter
- Supports window clip
- Supports FillRectangle, BitBlit, StretchBlit and MaskBlit
- Supports horizontal and vertical flip, clockwise 0/90/180/270 degree rotate for normal buffer
- Supports horizontal flip, clockwise 0/90/270 degree rotate for LBC buffer

### 2.3.6 Video Output

#### 2.3.6.1 RGB and LVDS LCD

- Supports RGB interface with DE/SYNC mode, up to 1920 x 1080@60fps
- Supports serial RGB/dummy RGB interface, up to 800 x 480@60fps
- Supports LVDS interface with dual link, up to 1920 x 1080@60fps
- Supports LVDS interface with single link, up to 1366 x 768@60fps
- Supports i8080 interface, up to 800 x 480@60fps
- Supports BT656 interface for NTSC and PAL
- RGB666 and RGB565 with dither function
- Gamma correction with R/G/B channel independence

#### 2.3.6.2 MIPI DSI

- Compliance with MIPI DSI v1.01
- Supports 4-lane MIPI DSI, up to 1280x720@60fps (for T113-S2) and 1920 x 1200@60fps (for others) resolution
- Supports non-burst mode with sync pulse/sync event and burst mode
- Supports pixel format: RGB888, RGB666, RGB666 loosely packed and RGB565
- Supports continuous and non-continuous lane clock modes
- Supports bidirectional communication of all generic commands in LP through data lane 0
- Supports low power data transmission
- Supports ULPS and escape modes
- Hardware checksum capabilities

### 2.3.6.3 CVBS OUT

- 1-channel CVBS output
- Supports NTSC and PAL format
- Plug status auto detecting
- 10 bits DAC output

## 2.3.7 Video Input

### 2.3.7.1 Parallel CSI

- Supports 8-bit digital camera interface (RAW8/YUV422/YUV420)
- Supports BT656, BT601 interface (YUV422)
- Supports ITU-R BT.656 time-multiplexed format up to 2\*1080p@30fps in DDR sample mode
- Maximum pixel clock of 148.5 MHz
- Supports de-interlacing for interlace video input
- Supports conversion from YUV422 to YUV420, YUV422 to YUV400, YUV420 to YUV400
- Supports horizontal and vertical flip

### 2.3.7.2 CVBS IN

- 2-channel CVBS input and 1-channel CVBS decoder
- Supports NTSC and PAL format
- Supports YUV422/YUV420 format
- With 1 channel 3D comb filter
- Detection for signal locked and 625 lines
- Programmable brightness, contrast, and saturation
- 10-bit video ADCs

## 2.3.8 System Peripherals

### 2.3.8.1 Timer

- The timer module implements the timing and counting functions, which includes timer0, timer1, watchdog, and audio video synchronization (AVS)
- The timer0/timer1 is a 32-bit down counter. The timer0 and timer1 are completely consistent
- The watchdog is used to transmit a reset signal to reset the entire system when an exception occurs in the system
- The AVS is used to synchronize the audio and video. The AVS sub-block includes AVS0 and AVS1, which are completely consistent

### 2.3.8.2 High Speed Timer (HSTimer)

- The HSTimer module consists of HSTimer0 and HSTimer1. HSTimer0 and HSTimer1 are down counters that implement timing and counting functions. They are completely consistent.
- Configurable 56-bit down timer
- Supports 5 prescale factors
- The clock source is synchronized with AHB0 clock, much more accurate than other timers
- Supports 2 working modes: periodic mode and single counting mode
- Generates an interrupt when the count is decreased to 0

### 2.3.8.3 GIC

- Supports 16 Software Generated Interrupts (SGIs), 16 Private Peripheral Interrupts (PPIs), and 192 Shared Peripheral Interrupts (SPIs)
- Software-configurable interrupts can be:
  - Enabled or disabled
  - Assigned to one of two groups: Group 0 or Group 1
  - Prioritized
  - Signaled to different processors in multiprocessor implementations
  - Either level-sensitive or edge-triggered
- GIC security extensions

- Uses Group 0 interrupts as Secure interrupts, and Group 1 interrupts as Non-secure interrupts
- Uses the FIQ interrupt request to signal Secure interrupts to a connected processor. The GIC-400 always signals Group 1 interrupts using the IRQ interrupt request

#### 2.3.8.4 DMAC

- Up to 16-ch DMA
- Provides 32 peripheral DMA requests for data reading and 32 peripheral DMA requests for data writing
- Flexible data width of 8/16/32/64-bit
- Programmable DMA burst length
- Supports linear and IO address modes
- Supports data transfer types with memory-to-memory, memory-to-peripheral, peripheral-to-memory, peripheral-to-peripheral
- Supports transfer with linked list
- DRQ response includes waiting mode and handshake mode
- DMA channel supports pause function
- Memory devices support non-aligned transform

#### 2.3.8.5 Clock Controller Unit (CCU)

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

#### 2.3.8.6 Thermal Sensor Controller (THS)

- One thermal sensor located in CPU
- Temperature accuracy:  $\pm 3^{\circ}\text{C}$  from  $0^{\circ}\text{C}$  to  $+100^{\circ}\text{C}$ ,  $\pm 5^{\circ}\text{C}$  from  $-25^{\circ}\text{C}$  to  $+125^{\circ}\text{C}$
- Averaging filter for thermal sensor reading

- Supports over-temperature protection interrupt and over-temperature alarm interrupt

### 2.3.8.7 LDO Power

- Integrated 2 LDOs (LDOA, LDOB)
- LDOA: 1.8 V power output, LDOB: 1.35 V/1.5 V/1.8 V power output
- LDOA for IO and analog module
- Input voltage is 2.4 V to 3.6 V

### 2.3.8.8 RTC

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

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

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

### 2.3.8.10 Message Box (MSGBOX)

- Supports two CPU to transmit information through channels. Each CPU has a MSGBOX
  - CPU 0: ARM CPUX
  - CPU 1: DSP
  - CPU 2: RISC-V
- The channel between two CPU has 4 channels, and the FIFO depth of a channel is  $8 \times 32$  bits

### 2.3.8.11 Spinlock

- Provides hardware synchronization mechanism in multi-core systems
- Supports 32 lock units
- Two kinds of lock status: locked and unlocked
- Lock time of the processor is predictable (less than 200 cycles)

## 2.3.9 Audio Interfaces

### 2.3.9.1 Audio Codec

- Two audio digital-to-analog converter (DAC) channels
  - Supports 16-bit and 20-bit sample resolution
  - 8 kHz to 192 kHz DAC sample rate
  - $100 \pm 2$  dB SNR@A-weight,  $-85 \pm 3$  dB THD+N
- One audio output:
  - One stereo headphone output: HPOUTL/R
- Three audio analog-to-digital converter (ADC) channels
  - Supports 16-bit and 20-bit sample resolution
  - 8 kHz to 48 kHz ADC sample rate
  - $95 \pm 3$  dB SNR@A-weight,  $-80 \pm 3$  dB THD+N
- Three audio inputs:
  - One differential microphone input: MICIN3P/3N, or one single-end microphone input: MICIN3P

- One stereo LINEIN input: LINEINL/R
- One stereo FMIN input: FMINL/R
- Stereo headphone driver
  - $95 \pm 3$  dB SNR@A-weight
  - Output Level  $0.55$  Vrms@ $10$  k $\Omega$ /THD+N  $-77 \pm 3$  dB,  $0.37$  Vrms@ $16$   $\Omega$ /THD+N  $-40$  dB
- Supports Dynamic Range Controller adjusting the DAC playback and ADC recording
- One  $128 \times 20$ -bits FIFO for DAC data transmit, one  $128 \times 20$ -bits FIFO for ADC data receive
- Programmable FIFO thresholds
- Supports interrupts and DMA
  - Internal HPLDO output for HPVCC
  - Internal ALDO output for AVCC

### 2.3.9.2 I2S/PCM

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

- Supports master/slave mode

### 2.3.9.3 DMIC

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

### 2.3.9.4 One Wire Audio (OWA)

- One OWA TX
- Compliance with S/PDIF interface
- IEC-60958 transmitter functionality
- Supports 16-bit, 20-bit, and 24-bit data formats
- One 128×24bits TXFIFO for audio data transfer
- Programmable FIFO thresholds
- Supports TX DMA slave interface
- Function clock includes 24.576 MHz and 22.579 MHz frequency
- Hardware parity generation on the transmitter
- Supports channel status insertion for the transmitter
- Supports interrupts and DMA

## 2.3.10 Security System

### 2.3.10.1 Crypto Engine (CE)

- Supports Symmetrical algorithm for encryption and decryption: AES, DES, TDES
  - Supports ECB, CBC, CTS, CTR, CFB, OFB mode for AES
  - Supports 128/192/256-bit key for AES
  - Supports ECB, CBC, CTR mode for DES/TDES
- Supports Hash algorithm for tamper proofing: MD5, SHA, HMAC
  - Supports SHA1, SHA224, SHA256, SHA384, SHA512 for SHA

- Supports HMAC-SHA1, HMAC-SHA256 for HMAC
- Supports multi-package mode for MD5/SHA1/SHA224/SHA256/SHA384/SHA512
- Supports Asymmetrical algorithm for signature verification: RSA
  - RSA supports 512/1024/2048-bit width
- Supports 160-bit hardware PRNG with 175-bit seed
- Supports 256-bit hardware TRNG
- Internal DMA controller for data transfer with memory

#### 2.3.10.2 Security ID (SID)

- Supports 2 Kbits eFuse
- Backup eFuse information by using SID\_SRAM
- Burning the key to the SID
- Reading the key use status in the SID
- Loading the key to the CE

#### 2.3.10.3 Secure Memory Control (SMC)

- The SMC is always secure, only secure CPU can access the SMC
- Sets secure area of DRAM
- Sets secure property that Master accesses to DRAM

#### 2.3.10.4 Secure Peripherals Control (SPC)

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

### 2.3.11 External Peripherals

#### 2.3.11.1 USB DRD

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

#### 2.3.11.2 USB HOST

- One USB 2.0 HOST (USB1), with integrated USB 2.0 analog PHY

- Complies with USB2.0 Specification
- Supports USB2.0 Host function
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
  - Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) Device
  - Supports only 1 USB Root port shared between EHCI and OHCI
- An internal DMA Controller for data transfer with memory

### 2.3.11.3 EMAC

- One EMAC interface for connecting external Ethernet PHY
- 10/100/1000 Mbit/s Ethernet port with RGMII and RMII interfaces
- Compliant with IEEE 802.3-2002 standard
- Supports both full-duplex and half-duplex operation
- Provides the management data input/output (MDIO) interface for PHY device configuration and management with configurable clock frequencies
- Programmable frame length to support Standard or Jumbo Ethernet frames with sizes up to 16 KB
- Supports a variety of flexible address filtering modes
- Separate 32-bit status returned for transmission and reception packets
- Optimization for packet-oriented DMA transfers with frame delimiters
  - Supports linked-list descriptor list structure
  - Descriptor architecture, allowing large blocks of data transfer with minimum CPU intervention; each descriptor can transfer up to 4 KB of data
  - Comprehensive status reporting for normal operation and transfers with errors
- 4 KB TXFIFO for transmission packets and 16 KB RXFIFO for reception packets
- Programmable interrupt options for different operational conditions

### 2.3.11.4 UART

- Up to 6 UART controllers (UART0, UART1, UART2, UART3, UART4, UART5)

- UART0, UART4, UART5: 2-wire; UART1, UART2, UART3: 4-wire
- Compatible with industry-standard 16450/16550 URTAs
- Supports IrDA-compatible slow infrared (SIR) format
- Two separate FIFOs: one is RX FIFO, and the other is TX FIFO
  - Each of them is 64 bytes (For UART0)
  - Each of them is 256 bytes (For UART1, UART2, UART3, UART4, and UART5)
- The working reference clock is from the APB bus clock
  - Speed up to 4 Mbit/s with 64 MHz APB clock
  - Speed up to 1.5 Mbit/s with 24 MHz APB clock
- 5 to 8 data bits for RS-232 characters, or 9 bits RS-485 format
- 1, 1.5 or 2 stop bits
- Programmable parity (even, odd, or no parity)
- Supports TX/RX DMA slave controller interface
- Supports software/hardware flow control
- Supports RX DMA Master interface (Only for UART1)
- Supports auto-flow by using CTS & RTS (Only for UART1/2/3)

### 2.3.11.5 Two Wire Interface (TWI)

- Up to 4 TWI controllers (TWI0, TWI1, TWI2, TWI3)
- Compliant with I2C bus standard
- Supports standard mode (up to 100 kbit/s) and fast mode (up to 400 kbit/s)
- Supports 7-bit and 10-bit device addressing modes
- Supports master mode or slave mode
- Master mode features:
  - Supports the bus arbitration in the case of multiple master devices
  - Supports clock synchronization and bit and byte waiting
    - Supports packet transmission and DMA
- Slave mode features:
  - Interrupt on address detection

- The TWI controller includes one TWI engine and one TWI driver. And the TWI driver supports packet transmission and DMA mode when TWI works in master mode

### 2.3.11.6 SPI and SPI\_DBI

- Up to 2 SPI controllers (SPI0, SPI1)
- The SPI0 only supports SPI mode; The SPI1 supports SPI mode and display bus interface (DBI) mode
- SPI mode:
  - Full-duplex synchronous serial interface
    - Master/slave configurable
    - Mode0 to Mode3 are supported for both transmit and receive operations
    - 8-bit wide by 64-entry FIFO for both transmit and receive data
    - Polarity and phase of the Chip Select (SPI-CS) and SPI Clock (SPI-CLK) are configurable
    - Supports 3-wire/4-wire SPI
    - Supports programmable serial data frame length: 1-bit to 32-bit
    - Supports Standard SPI, Dual-Output/Dual-Input SPI, Dual IO SPI, Quad-Output/Quad-Input SPI
- DBI mode:
  - Supports DBI Type C 3 Line/4 Line Interface Mode
  - Supports 2 Data Lane Interface Mode
  - Supports RGB111/444/565/666/888 video format
  - Maximum resolution of RGB666 240 x 320@30Hz with single data lane
  - Maximum resolution of RGB888 240 x 320@60Hz or 320 x 480@30Hz with dual data lane
  - Supports Tearing effect
  - Supports software flexible control video frame rate

### 2.3.11.7 CIR Receiver (CIR\_RX)

- One CIR\_RX interface (IR-RX)
- Full physical layer implementation
- Supports NEC format infra data

- Supports CIR for remote control or wireless keyboard
- 64x8 bits FIFO for data buffer
- Sample clock up to 1 MHz

### 2.3.11.8 CIR Transmitter (CIR\_TX)

- One CIR\_TX interface (IR-TX)
- Supports arbitrary wave generator
- Configurable carrier frequency
- Supports handshake mode and waiting mode of DMA
- 128 bytes FIFO for data buffer

### 2.3.11.9 PWM

- Supports 8 independent PWM channels (PWM0 to PWM7)
  - Supports PWM continuous mode output
  - Supports PWM pulse mode output, and the pulse number is configurable
  - Output frequency range: 0 to 24 MHz or 100 MHz
  - Various duty-cycle: 0% to 100%
  - Minimum resolution: 1/65536
- Supports 4 complementary pairs output
  - PWM01 pair (PWM0 + PWM1), PWM23 pair (PWM2 + PWM3), PWM45 pair (PWM4 + PWM5), PWM67 pair (PWM6 + PWM7)
  - Supports dead-zone generator, and the dead-zone time is configurable
- Supports 4 group of PWM channel output for controlling stepping motors
  - Supports any plural channels to form a group, and output the same duty-cycle pulse
  - In group mode, the relative phase of the output waveform for each channel is configurable
- Supports 8 channels capture input
  - Supports rising edge detection and falling edge detection for input waveform pulse
  - Supports pulse-width measurement for input waveform pulse

### 2.3.11.10 General Purpose ADC (GPADC)

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

### 2.3.11.11 Touch Panel ADC (TPADC)

- 12 bit SAR type A/D converter
- Configurable sample frequency up to 1 MHz
- One 32x12 FIFO for storing A/D conversion result
- Supports DMA slave interface
- Supports 4-wire resistive touch panel input detection
  - Supports pen down detection with programmable sensitivity
  - Supports single touch coordinate measurement
  - Supports dual touch detection
  - Supports touch pressure measurement with programmable threshold
  - Supports median and averaging filter for noise reduction
  - Supports X and Y coordinate exchange function
- Supports Aux ADC with up to 4 channels

### 2.3.11.12 LEDC

- LEDC is used to control the external intelligent control LED lamp
- Configurable LED output high/low level width
- Configurable LED reset time

- LEDC data supports DMA configuration mode and CPU configuration mode
- Maximum 1024 LEDs serial connect
- LED data transfer rate up to 800 kbit/s

### 2.3.11.13 CAN

- Supports industry-standard AMBA Peripheral Bus (APB) and it is fully compliant with the AMBA Specification Revision 2.0
- Supports APB 32-bit bus width operation
- Supports the CAN 2.0A and 2.0B protocol specification
- Supports one-shot transmission option
- Supports two configurable filter modes
- Supports listen only mode
- Supports self-test mode

### 2.3.12 Package

- eLQFP128, 14 mm x 14 mm x 1.4 mm

## 2.4 Block Diagram

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

**Figure 2-1 T113x System Block Diagram**



Figure 2-2 to Figure 2-5 show the typical solution diagrams.

### Figure 2-2 Car MP5 Solution



### Figure 2-3 Car Instrument Solution



Figure 2-4 HMI Solution



Figure 2-5 PLC Solution



# Contents

|       |                                                   |     |
|-------|---------------------------------------------------|-----|
| 2     | Product Description .....                         | 7   |
| 3     | System.....                                       | 36  |
| 3.1   | Memory Mapping .....                              | 36  |
| 3.2   | CPUX Configuration.....                           | 41  |
| 3.2.1 | Overview .....                                    | 41  |
| 3.2.2 | Functional Descriptions.....                      | 41  |
| 3.2.3 | Cluster 0 Configuration Register List.....        | 43  |
| 3.2.4 | Cluster 0 Configuration Register Description..... | 44  |
| 3.2.5 | CPU Subsystem Control Register List .....         | 52  |
| 3.2.6 | CPU Subsystem Control Register Description .....  | 53  |
| 3.3   | Clock Controller Unit (CCU).....                  | 57  |
| 3.3.1 | Overview .....                                    | 57  |
| 3.3.2 | Block Diagram .....                               | 57  |
| 3.3.3 | Functional Description .....                      | 58  |
| 3.3.4 | Programming Guidelines.....                       | 63  |
| 3.3.5 | Register List .....                               | 69  |
| 3.3.6 | Register Description .....                        | 73  |
| 3.4   | BROM System.....                                  | 160 |
| 3.4.1 | Overview .....                                    | 160 |
| 3.4.2 | Functional Description .....                      | 160 |
| 3.5   | System Configuration.....                         | 171 |
| 3.5.1 | Overview .....                                    | 171 |
| 3.5.2 | Register List .....                               | 171 |
| 3.5.3 | Register Description .....                        | 171 |
| 3.6   | RISC-V System .....                               | 179 |
| 3.6.1 | Overview .....                                    | 179 |
| 3.6.2 | Block Diagram .....                               | 179 |
| 3.6.3 | Register List .....                               | 180 |
| 3.7   | Timer .....                                       | 196 |

|                                                      |     |
|------------------------------------------------------|-----|
| 3.7.1 Overview .....                                 | 196 |
| 3.7.2 Block Diagram .....                            | 197 |
| 3.8 High Speed Timer .....                           | 215 |
| 3.8.1 Overview .....                                 | 215 |
| 3.8.2 Block Diagram .....                            | 215 |
| 3.8.3 Functional Description .....                   | 215 |
| 3.8.4 Programming Guidelines.....                    | 219 |
| 3.8.5 Register List.....                             | 219 |
| 3.8.6 Register Description .....                     | 220 |
| 3.9 Generic Interrupt Controller (GIC) .....         | 227 |
| 3.9.1 Overview .....                                 | 227 |
| 3.9.2 Functional Description .....                   | 227 |
| 3.10 Platform-Level Interrupt Controller (PLIC)..... | 235 |
| 3.10.1 Overview .....                                | 235 |
| 3.10.2 Functional Description .....                  | 235 |
| 3.10.3 Register List.....                            | 242 |
| 3.10.4 Register Description .....                    | 242 |
| 3.11 Direct Memory Access Controller (DMAC).....     | 246 |
| 3.11.1 Overview .....                                | 246 |
| 3.11.2 Block Diagram .....                           | 246 |
| 3.11.3 Functional Description .....                  | 247 |
| 3.11.4 Programming Guidelines.....                   | 256 |
| 3.11.5 Register List.....                            | 259 |
| 3.11.6 Register Description .....                    | 260 |
| 3.12 Thermal Sensor Controller (THS) .....           | 280 |
| 3.12.1 Overview .....                                | 280 |
| 3.12.2 Block Diagram .....                           | 280 |
| 3.12.3 Functional Description .....                  | 280 |
| 3.12.4 Programming Guidelines.....                   | 282 |
| 3.12.5 Register List.....                            | 284 |
| 3.12.6 Register Description .....                    | 284 |
| 3.13 IOMMU .....                                     | 290 |
| 3.13.1 Overview .....                                | 290 |

|                                     |     |
|-------------------------------------|-----|
| 3.13.2 Block Diagram .....          | 290 |
| 3.13.3 Functional Description ..... | 291 |
| 3.13.4 Programming Guidelines.....  | 301 |
| 3.13.5 Register List.....           | 302 |
| 3.13.6 Register Description.....    | 306 |
| 3.14 Message Box .....              | 376 |
| 3.14.1 Overview .....               | 376 |
| 3.14.2 Block Diagram .....          | 376 |
| 3.14.3 Functional Description ..... | 377 |
| 3.14.4 Programming Guidelines.....  | 378 |
| 3.14.5 Register List.....           | 379 |
| 3.14.6 Register Description .....   | 380 |
| 3.15 Spinlock .....                 | 386 |
| 3.15.1 Overview .....               | 386 |
| 3.15.2 Block Diagram .....          | 386 |
| 3.15.3 Functional Description ..... | 386 |
| 3.15.4 Programming Guidelines.....  | 388 |
| 3.15.5 Register List.....           | 391 |
| 3.15.6 Register Description .....   | 391 |
| 3.16 RTC .....                      | 395 |
| 3.16.1 Overview .....               | 395 |
| 3.16.2 Block Diagram .....          | 395 |
| 3.16.3 Functional Description ..... | 396 |
| 3.16.4 Programming Guidelines.....  | 400 |
| 3.16.5 Register List .....          | 402 |
| 3.16.6 Register Description .....   | 403 |

# Figures

|                                                              |     |
|--------------------------------------------------------------|-----|
| Figure 3-1 Default Power Domain of Cluster0 .....            | 43  |
| Figure 3-2 CCU Block Diagram .....                           | 57  |
| Figure 3-3 System Bus Tree.....                              | 58  |
| Figure 3-4 Module Clock Generation .....                     | 59  |
| Figure 3-5 PLL Distribution.....                             | 60  |
| Figure 3-6 Boot Process in Normal BROM Mode.....             | 164 |
| Figure 3-7 Boot Process in Secure BROM Mode .....            | 165 |
| Figure 3-8 NON_CPU0 Boot Process Diagram .....               | 166 |
| Figure 3-9 CPU0 Hotplug Process Diagram .....                | 167 |
| Figure 3-10 Mandatory Upgrade Process .....                  | 168 |
| Figure 3-11 USB FEL Process .....                            | 169 |
| Figure 3-12 RISC-V System Block Diagram .....                | 180 |
| Figure 3-13 Timer Block Diagram.....                         | 197 |
| Figure 3-14 Block Diagram for the Timer .....                | 197 |
| Figure 3-15 Block Diagram for the Watchdog.....              | 199 |
| Figure 3-16 Block Diagram for the AVS.....                   | 201 |
| Figure 3-17 HSTimer Block Diagram .....                      | 215 |
| Figure 3-18 Typical Application for HSTimer.....             | 216 |
| Figure 3-19 HSTimer Initialization Process.....              | 218 |
| Figure 3-20 DMAC Block Diagram.....                          | 246 |
| Figure 3-21 DMAC Typical Application Diagram.....            | 248 |
| Figure 3-22 DMA Descriptor .....                             | 250 |
| Figure 3-23 DMA Chain Transfer.....                          | 252 |
| Figure 3-24 Workflow of the DMAC Handshake Mode .....        | 255 |
| Figure 3-25 DMAC Transfer Process .....                      | 257 |
| Figure 3-26 THS Block Diagram .....                          | 280 |
| Figure 3-27 Thermal Sensor Timing Requirement .....          | 281 |
| Figure 3-28 Thermal Sensor Controller Interrupt Source ..... | 281 |
| Figure 3-29 THS Initial Process .....                        | 282 |
| Figure 3-30 IOMMU Block Diagram .....                        | 291 |

|                                                                         |     |
|-------------------------------------------------------------------------|-----|
| Figure 3-31 Internal Switch Process .....                               | 295 |
| Figure 3-32 VA-PA Switch Process .....                                  | 296 |
| Figure 3-33 Invalid TLB Address Range .....                             | 297 |
| Figure 3-34 Level1 Page Table Format.....                               | 299 |
| Figure 3-35 Level1 Page Table Format.....                               | 299 |
| Figure 3-36 Read/Write Permission Control .....                         | 300 |
| Figure 3-37 Message Box Block Diagram .....                             | 376 |
| Figure 3-38 The Communication Process between MSGBOX0 and MSGBOX1 ..... | 379 |
| Figure 3-39 Spinlock Block Diagram .....                                | 386 |
| Figure 3-40 Spinlock Typical Application Diagram .....                  | 387 |
| Figure 3-41 Spinlock State Machine.....                                 | 388 |
| Figure 3-42 CPUX and DSP Taking/Freeing Spinlock0 Process .....         | 389 |
| Figure 3-43 RTC Block Diagram .....                                     | 396 |
| Figure 3-44 RTC Application Diagram .....                               | 397 |
| Figure 3-45 RTC Clock Tree .....                                        | 397 |
| Figure 3-46 RTC Counter .....                                           | 398 |
| Figure 3-47 RTC 1 kHz Counter Step Structure .....                      | 399 |

# Tables

|                                                                            |     |
|----------------------------------------------------------------------------|-----|
| Table 3-1 Reset Signal Description .....                                   | 42  |
| Table 3-2 Power Domain of Modules in the CPU Subsystem .....               | 42  |
| Table 3-3 PLL Typical Application .....                                    | 61  |
| Table 3-4 PLL Features .....                                               | 62  |
| Table 3-5 Recommended Values for Configuration Factors of PLL_AUDIO1 ..... | 64  |
| Table 3-6 BOOT_MODE Setting .....                                          | 161 |
| Table 3-7 GPIO Boot Select Configuration .....                             | 161 |
| Table 3-8 Groups of eFuse_Boot_Select .....                                | 162 |
| Table 3-9 eFuse Boot Select Setting .....                                  | 162 |
| Table 3-10 Fast Boot Select Setting .....                                  | 170 |
| Table 3-11 Interrupt Sources .....                                         | 227 |
| Table 3-12 Interrupt Sources .....                                         | 235 |
| Table 3-13 DMA Sub-blocks .....                                            | 247 |
| Table 3-14 DMA DRQ Type .....                                              | 248 |
| Table 3-15 Source/Destination Address Distribution .....                   | 251 |
| Table 3-16 THS Information in the SID .....                                | 282 |
| Table 3-17 Correspondence Relation between Master and Module .....         | 291 |
| Table 3-18 Relation between ACI and Domain .....                           | 300 |
| Table 3-19 RTC External Signals .....                                      | 396 |
| Table 3-20 RTC Counter Changing Range .....                                | 399 |

## 3 System

### 3.1 Memory Mapping

| Module                  | Address (It is for Cluster CPU) | Size                                                |
|-------------------------|---------------------------------|-----------------------------------------------------|
| <b>BROM &amp; SRAM</b>  |                                 |                                                     |
| N-BROM                  | 0x0000 0000—0x0000 BFFF         | 48 KB                                               |
| S-BROM                  | 0x0000 0000—0x0000 8FFF         | 36 KB                                               |
| SRAM A1                 | 0x0002 0000---0x0002 7FFF       | 32 KB                                               |
| DSP0 IRAM               | 0x0002 8000---0x0003 7FFF       | 64 KB<br>The local sram is switched to system boot. |
| DSP0 DRAM0              | 0x0003 8000---0x0003 FFFF       | 32 KB<br>The local sram is switched to system boot. |
| DSP0 DRAM1              | 0x0004 0000---0x0004 7FFF       | 32 KB<br>The local sram is switched to system boot. |
| DSP0 IRAM (local sram)  | 0x0040 0000---0x0040 FFFF       | 64 KB<br>The local sram is switched to DSP.         |
| DSP0 DRAM0 (local sram) | 0x0042 0000---0x0042 7FFF       | 32 KB<br>The local sram is switched to DSP.         |
| DSP0 DRAM1 (local sram) | 0x0044 0000---0x0044 7FFF       | 32 KB<br>The local sram is switched to DSP.         |
| <b>DSP_SYS Related</b>  |                                 |                                                     |
| DSP_CFG                 | 0x0170 0000---0x0170 03FF       | 1 KB                                                |
| DSP_WDG                 | 0x0170 0400---0x0170 07FF       | 1 KB                                                |
| DSP_INTC                | 0x0170 0800---0x0170 0BFF       | 1 KB                                                |
| DSP_TZMA                | 0x0170 0C00---0x0170 0FFF       | 1 KB                                                |
| DSP_MSGBOX              | 0x0170 1000---0x0170 1FFF       | 4 KB                                                |
| <b>VE_SYS Related</b>   |                                 |                                                     |
| VE                      | 0x01C0 E000---0x01C0 FFFF       | 8 KB                                                |
| <b>SP0 (SYS Domain)</b> |                                 |                                                     |
| GPIO                    | 0x0200 0000---0x0200 07FF       | 2 KB                                                |
| SPC                     | 0x0200 0800---0x0200 0BFF       | 1 KB                                                |

| Module                  | Address (It is for Cluster CPU) | Size  |
|-------------------------|---------------------------------|-------|
| PWM                     | 0x0200 0C00---0x0200 0FFF       | 1 KB  |
| CCU                     | 0x0200 1000---0x0200 1FFF       | 4 KB  |
| CIR_TX                  | 0x0200 3000---0x0200 33FF       | 1 KB  |
| TZMA                    | 0x0200 4000---0x0200 43FF       | 1 KB  |
| LEDC                    | 0x0200 8000---0x0200 83FF       | 1 KB  |
| GPADC                   | 0x0200 9000---0x0200 93FF       | 1 KB  |
| THS                     | 0x0200 9400---0x0200 97FF       | 1 KB  |
| TPADC                   | 0x0200 9C00---0x0200 9FFF       | 1 KB  |
| IOMMU                   | 0x0201 0000---0x0201 FFFF       | 64 KB |
| Audio Codec             | 0x0203 0000---0x0203 0FFF       | 4 KB  |
| DMIC                    | 0x0203 1000---0x0203 13FF       | 1 KB  |
| I2S1                    | 0x0203 3000---0x0203 3FFF       | 4 KB  |
| I2S2                    | 0x0203 4000---0x0203 4FFF       | 4 KB  |
| OWA                     | 0x0203 6000---0x0203 63FF       | 1 KB  |
| TIMER                   | 0x0205 0000---0x0205 0FFF       | 4 KB  |
| <b>SP1 (SYS Domain)</b> |                                 |       |
| UART0                   | 0x0250 0000---0x0250 03FF       | 1 KB  |
| UART1                   | 0x0250 0400---0x0250 07FF       | 1 KB  |
| UART2                   | 0x0250 0800---0x0250 0BFF       | 1 KB  |
| UART3                   | 0x0250 0C00---0x0250 0FFF       | 1 KB  |
| UART4                   | 0x0250 1000---0x0250 13FF       | 1 KB  |
| UART5                   | 0x0250 1400---0x0250 17FF       | 1 KB  |
| TWI0                    | 0x0250 2000---0x0250 23FF       | 1 KB  |
| TWI1                    | 0x0250 2400---0x0250 27FF       | 1 KB  |
| TWI2                    | 0x0250 2800---0x0250 2BFF       | 1 KB  |
| TWI3                    | 0x0250 2C00---0x0250 2FFF       | 1 KB  |
| <b>SH0 (SYS Domain)</b> |                                 |       |
| SYSCTRL                 | 0x0300 0000---0x0300 0FFF       | 4 KB  |
| DMAC                    | 0x0300 2000---0x0300 2FFF       | 4 KB  |
| CPUX_MSGBOX             | 0x0300 3000---0x0300 3FFF       | 4 KB  |
| SPINLOCK                | 0x0300 5000---0x0300 5FFF       | 4 KB  |
| SID                     | 0x0300 6000---0x0300 6FFF       | 4 KB  |
| SMC                     | 0x0300 7000---0x0300 7FFF       | 4 KB  |
| HSTIMER                 | 0x0300 8000---0x0300 8FFF       | 4 KB  |

| Module                                    | Address (It is for Cluster CPU) | Size                                                                                      |
|-------------------------------------------|---------------------------------|-------------------------------------------------------------------------------------------|
| DCU                                       | 0x0301 0000---0x0301 FFFF       | 64 KB                                                                                     |
| GIC                                       | 0x0302 0000---0x0302 FFFF       | 64 KB                                                                                     |
| CE_NS                                     | 0x0304 0000---0x0304 07FF       | 2 KB                                                                                      |
| CE_S                                      | 0x0304 0800---0x0304 0FFF       | 2 KB                                                                                      |
| CE_KEY_SRAM                               | 0x0304 1000---0x0304 1FFF       | 4 KB (only CE access)                                                                     |
| MSI+MEMC                                  | 0x0310 2000---0x0330 1FFF       | 2 MB                                                                                      |
| <b>SH2 (SYS Domain)</b>                   |                                 |                                                                                           |
| SMHC0                                     | 0x0402 0000---0x0402 0FFF       | 4 KB                                                                                      |
| SMHC1                                     | 0x0402 1000---0x0402 1FFF       | 4 KB                                                                                      |
| SMHC2                                     | 0x0402 2000---0x0402 2FFF       | 4 KB                                                                                      |
| SPI0                                      | 0x0402 5000---0x0402 5FFF       | 4 KB                                                                                      |
| SPI1                                      | 0x0402 6000---0x0402 6FFF       | 4 KB                                                                                      |
| USB0                                      | 0x0410 0000---0x041F FFFF       | 1 MB                                                                                      |
| USB1                                      | 0x0420 0000---0x042F FFFF       | 1 MB                                                                                      |
| EMAC                                      | 0x0450 0000---0x0450 FFFF       | 64 KB                                                                                     |
| <b>VIDEO_OUT_SYS Related (SYS Domain)</b> |                                 |                                                                                           |
| DE                                        | 0x0500 0000---0x053F FFFF       | 4 MB                                                                                      |
| DI                                        | 0x0540 0000---0x0540 FFFF       | 64 KB                                                                                     |
| G2D                                       | 0x0541 0000---0x0544 FFFF       | 256 KB                                                                                    |
| DSI                                       | 0x0545 0000---0x0545 1FFF       | 8 KB                                                                                      |
| DISPLAY_TOP                               | 0x0546 0000---0x0546 0FFF       | 4 KB                                                                                      |
| TCON_LCD0                                 | 0x0546 1000---0x0546 1FFF       | 4 KB                                                                                      |
| TCON_TV0                                  | 0x0547 0000---0x0547 0FFF       | 4 KB                                                                                      |
| TVE_TOP                                   | 0x0560 0000---0x0560 3FFF       | 16 KB                                                                                     |
| TV Encoder                                | 0x0560 4000---0x0560 7FFF       | 16 KB                                                                                     |
| <b>VIDEO_IN_SYS Related (SYS Domain)</b>  |                                 |                                                                                           |
| CSI                                       | 0x0580 0000---0x05BF FFFF       | 4 MB                                                                                      |
| TVD_TOP                                   | 0x05C0 0000---0x05C0 0FFF       | 4 KB                                                                                      |
| TV Decoder                                | 0x05C0 1000---0x05C0 1FFF       | 4 KB                                                                                      |
| <b>RISC-V_SYS Related (SYS Domain)</b>    |                                 |                                                                                           |
| RISCV_BROM                                | 0x0600 0000---0x0600 FFFF       | 64 KB<br>Address mapping which RISC-V core<br>accesses BROM:<br>0x0000 0000---0x0000 FFFF |

| Module                         | Address (It is for Cluster CPU) | Size |
|--------------------------------|---------------------------------|------|
| RISCV_CFG                      | 0x0601 0000---0x0601 0FFF       | 4 KB |
| RISCV_WDG                      | 0x0601 1000---0x0601 1FFF       | 4 KB |
| RISCV_TIMESTAMP                | 0x0601 2000---0x0601 2FFF       | 4 KB |
| RISCV_MSGBOX                   | 0x0601 F000---0x0601 FFFF       | 4 KB |
| <b>APBS0</b>                   |                                 |      |
| CIR_RX                         | 0x0704 0000---0x0704 03FF       | 1 KB |
| <b>AHBS</b>                    |                                 |      |
| RTC                            | 0x0709 0000---0x0709 03FF       | 1 KB |
| <b>CPUX Related</b>            |                                 |      |
| CPU_SYS_CFG                    | 0x0810 0000---0x0810 03FF       | 1 KB |
| TimeStamp_STA                  | 0x0811 0000---0x0811 0FFF       | 4 KB |
| TimeStamp_CTRL                 | 0x0812 0000---0x0812 0FFF       | 4 KB |
| IDC                            | 0x0813 0000---0x0813 0FFF       | 4 KB |
| C0_CPUX_CFG                    | 0x0901 0000---0x0901 03FF       | 1 KB |
| C0_CPUX_MBIST                  | 0x0902 0000---0x0902 0FFF       | 4 KB |
| <b>DRAM Space (SYS Domain)</b> |                                 |      |
| DRAM SPACE                     | 0x4000 0000---0xBFFF FFFF       | 2 GB |

The following is the system memory mapping seen by the DSP0 host.

| Module         | Cacheable Property           | Address                   | Size   | Address Mapping Description                                                                                                              |
|----------------|------------------------------|---------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------|
| SRAM A1        | Non-Cacheable (Total 512 MB) | 0x0002 0000---0x0002 7FFF | 32 KB  | The start address of the default DSP.                                                                                                    |
| DSP0 IRAM      |                              | 0x0002 8000---0x0003 7FFF | 64 KB  | The DSP0 accesses the address through the external bus to operate the internal local SRAM.                                               |
| DSP0 DRAM0     |                              | 0x0003 8000---0x0003 FFFF | 32 KB  |                                                                                                                                          |
| DSP0 DRAM1     |                              | 0x0004 0000---0x0004 7FFF | 32 KB  |                                                                                                                                          |
| DSP0 IRAM      |                              | 0x0040 0000---0x0040 FFFF | 64 KB  | The DSP0 accesses the address through the internal bus to directly access the local SRAM, which is more efficient than the external bus. |
| DSP0 DRAM0     |                              | 0x0042 0000---0x0042 7FFF | 32 KB  |                                                                                                                                          |
| DSP0 DRAM1     |                              | 0x0044 0000---0x0044 7FFF | 32 KB  |                                                                                                                                          |
| L4_CONN_periph |                              | 0x0200 0000---0x09FF FFFF | 128 MB | System Peripherals                                                                                                                       |

| Module                           | Cacheable Property          | Address                   | Size   | Address Mapping Description                                                                               |
|----------------------------------|-----------------------------|---------------------------|--------|-----------------------------------------------------------------------------------------------------------|
| DSP_SYS_CFG                      |                             | 0x0170 0000---0x0170 0FFF | 4 KB   | Peripherals                                                                                               |
| DRAM SPACE                       |                             | 0x1000 0000---0x1FFF FFFF | 256 MB | The front 256 MB space of DDR (0x40000000-0x4FFFFFFF)<br>It requires DSP output AHB for address remapping |
| <b>Cacheable Mapping Area</b>    |                             |                           |        |                                                                                                           |
| SRAM                             | Cacheable<br>(Total 512 MB) | 0x2002 0000---0x2002 7FFF | 32 KB  | SRAM A1 has two addresses.                                                                                |
| DSPO IRAM                        |                             | 0x2002 8000---0x2003 7FFF | 64 KB  | The DSPO accesses the address through the external bus to operate the internal local SRAM.                |
| DSPO DRAM0                       |                             | 0x2003 8000---0x2003 FFFF | 32 KB  |                                                                                                           |
| DSPO DRAM1                       |                             | 0x2004 0000---0x2004 7FFF | 32 KB  |                                                                                                           |
| DRAM SPACE                       |                             | 0x3000 0000---0x3FFF FFFF | 256 MB | The front 256 MB space of DDR (0x40000000-0x47FFFFFF)<br>It requires DSP output AHB for address remapping |
| <b>DRAM Special Mapping Area</b> |                             |                           |        |                                                                                                           |
| DRAM SPACE                       | Non-Cacheable               | 0x4000 0000---0x7FFF FFFF | 1 GB   |                                                                                                           |
| DRAM SPACE                       | Cacheable Configurable      | 0x8000 0000---0xBFFF FFFF | 1 GB   | Reserved space                                                                                            |
| DRAM SPACE                       | Cacheable                   | 0xC000 0000---0xFFFF FFFF | 1 GB   | The front 1 GB space of DDR (0x40000000-0x7FFFFFFF)                                                       |

## 3.2 CPUX Configuration

### 3.2.1 Overview

CPUX indicates the ARM CPU subsystem. You can configure the CPUX via the CO\_CPUX\_CFG and CPU\_SUBSYS\_CTRL modules.

The CO\_CPUX\_CFG module is used for configuring Cluster0. Cluster0 is the only cluster which consists of dual-core Cortex<sup>TM</sup>-A7, 32 KB I-cache and 32 KB D-cache per core, and the shared 256 KB L2 cache. The CO\_CPUX\_CFG module includes the following features:

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

The CPU\_SUBSYS\_CTRL module is used for controlling CPU subsystem resources, such as GIC-400 and JTAG.

### 3.2.2 Functional Descriptions

#### 3.2.2.1 Signal Description

For details of A7 CPUX signals, refer to the technical reference manual of [DDI0464F\\_cortex\\_A7\\_mpcore\\_r0p5\\_trm.pdf](#).

#### 3.2.2.2 L2 Idle Mode

Enter the L2 idle mode by configuring the L2 cache of Cluster to enter the wait for interrupt (WFI) mode.

Follow the steps below:

1. Make sure CPU[1:0] of Cluster has entered the WFI mode. You can check it through bit[17:16] of [Cluster0 CPU Status Register](#).
2. Pull high the [ACINACTM](#) of Cluster by writing 1 to the bit0 of [Cluster 0 Control Register1](#).
3. Check whether L2 enters idle status by checking whether the [STANDBYWFL2](#) is high.

To exit the L2 idle mode, set the [ACINACTM](#) to low.

### 3.2.2.3 CPU Reset System

There are three levels of CPUX reset, with the scope size from small to large: core reset, power-on Reset, and H\_Reset.

The following table describes all the reset signals in the CPUX reset system.

**Table 3-1 Reset Signal Description**

| Reset Signal   | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CORE_RST       | This is the primary reset signal which resets the corresponding core logic, including NEON, VFP, Debug, ETM, breakpoint, and watchpoint logic.<br>It maps to a warm reset that covers the reset of the processor logic.                                                                                                                                                                      |
| PWRON_RST      | This power-on reset signal resets all the processor logic, including the Debug, ETM trace unit, breakpoint, watchpoint logic, and performance monitors logic.<br>It maps to a cold reset that covers the reset of the processor logic and the integrated debug functionality. It does not reset debug logic in the debug power domain.<br>PWRON_RST includes CORE_RST, ETM_RST, and DBG_RST. |
| H_RST          | H_RST includes PWRON_RST, L2_RST, MBIST_RST, SOC_DBG_RST, and CO_CPUX_CFG.                                                                                                                                                                                                                                                                                                                   |
| AXI2MBUS_RST   | This reset signal resets the AXI2MBUS interface logic circuit.                                                                                                                                                                                                                                                                                                                               |
| L2_RST         | This single, cluster-wide signal resets the L2 memory system and the logic in the SCU.                                                                                                                                                                                                                                                                                                       |
| ETM_RST        | This reset signal resets ETM debug logic circuit.                                                                                                                                                                                                                                                                                                                                            |
| DBG_RST        | In the processor power domain, this reset signal resets only the debug, breakpoint, and watchpoint logic.<br>In the debug power domain, it resets the debug logic for each processor.                                                                                                                                                                                                        |
| SOC_DBG_RST    | This reset signal resets all the debug logic. It includes DBG_RST.                                                                                                                                                                                                                                                                                                                           |
| MBIST_RST      | This reset signal resets all resettable registers in the cluster, for entry into and exit from MBIST mode.                                                                                                                                                                                                                                                                                   |
| CPU_SUBSYS_RST | CPU_SUBSYS_RST includes CO_H_RST, GIC-400, and CPU_SUBSYS_CTRL.                                                                                                                                                                                                                                                                                                                              |

### 3.2.2.4 CPUX Power Block Diagram

The following table shows the power domain of the modules in the CPU subsystem.

**Table 3-2 Power Domain of Modules in the CPU Subsystem**

| Power Domain | Modules                                    | Description                                                     |
|--------------|--------------------------------------------|-----------------------------------------------------------------|
| Cluster0     | Cluster0, CO_CPUX_CFG, and CO_MBIST        | Cluster0 circuit, CO_CPUX_CFG module, and CPU reset/power/mbist |
| System       | Timestamp, GIC, CPU_SUBSYS_CTRL, and Clock | Provides system source of CPU sub-system                        |

As shown in the table, C0\_CPUX\_CFG belongs to Cluster0 power domain and CPU\_SUBSYS\_CTRL belongs to the system power domain.

Because C0\_CPUX\_CFG and Cluster0 belong to the same power domain, C0\_CPUX\_CFG holds in the default state when Cluster0 restarts. You need to initial C0\_CPUX\_CFG via software after C0\_H\_RST is de-asserted.

The following figure shows the default power domain of Cluster0.

**Figure 3-1 Default Power Domain of Cluster0**



For Cluster0, the power switch of all CPU cores are on, the PWRON\_RST of all CPU cores are de-asserted, the CORE\_RST of CPU0 is de-asserted, and the CORE\_RST of CPU1 is asserted.

### 3.2.2.5 CPUX Power Block Diagram

The CPU-related operations, such as opening/closing cores, clustering switches, and querying status, require proper configurations of C0\_CPUX\_CFG module and the related system control resources like the bus and clock.

### 3.2.3 Cluster 0 Configuration Register List

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

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| C0_RST_CTRL   | 0x0000 | Cluster 0 Reset Control Register |
| C0_CTRL_REG0  | 0x0010 | Cluster 0 Control Register0      |
| C0_CTRL_REG1  | 0x0014 | Cluster 0 Control Register1      |
| C0_CTRL_REG2  | 0x0018 | Cluster 0 Control Register2      |
| CACHE_CFG_REG | 0x0024 | Cache Configuration Register     |

| Register Name     | Offset | Description                              |
|-------------------|--------|------------------------------------------|
| C0_CPU_STATUS     | 0x0080 | Cluster 0 CPU Status Register            |
| L2_STATUS_REG     | 0x0084 | Cluster 0 L2 Status Register             |
| DBG_REG0          | 0x00C0 | Cluster 0 Debug Control Register0        |
| DBG_REG1          | 0x00C4 | Cluster 0 Debug Control Register1        |
| AXI_MNT_CTRL_REG  | 0x00D0 | AXI Monitor Control Register             |
| AXI_MNT_PRD_REG   | 0x00D4 | AXI Monitor Period Register              |
| AXI_MNT_RLTCY_REG | 0x00D8 | AXI Monitor Read Total Latency Register  |
| AXI_MNT_WLTCY_REG | 0x00DC | AXI Monitor Write Total Latency Register |
| AXI_MNT_RREQ_REG  | 0x00E0 | AXI Monitor Read Request Times Register  |
| AXI_MNT_WREQ_REG  | 0x00E4 | AXI Monitor Write Request Times Register |
| AXI_MNT_RBD_REG   | 0x00E8 | AXI Monitor Read Bandwidth Register      |
| AXI_MNT_WBD_REG   | 0x00EC | AXI Monitor Write Bandwidth Register     |

### 3.2.4 Cluster 0 Configuration Register Description

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

| Offset: 0x0000 |            |             | Register Name: C0_RST_CTRL                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:29          | /          | /           | /                                                                                        |
| 28             | R/W        | 0x1         | DDR_RST<br>AXI2MBUS Logic Circuit Reset<br>0: Assert<br>1: De-assert                     |
| 27:26          | /          | /           | /                                                                                        |
| 25             | R/W        | 0x1         | MBIST_RST<br>CPUBIST Reset<br>The reset signal is for test.<br>0: Assert<br>1: De-assert |
| 24             | R/W        | 0x1         | SOC_DBG_RST<br>Cluster SoC Debug Reset<br>0: Assert<br>1: De-assert                      |

| Offset: 0x0000 |            |             | Register Name: C0_RST_CTRL                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 23:20          | R/W        | 0xF         | <p>ETM_RST<br/>Cluster ETM Reset Assert<br/>0: Assert<br/>1: De-assert</p>                                    |
| 19:16          | R/W        | 0xF         | <p>DBG_RST<br/>Cluster Debug Reset Assert<br/>0: Assert<br/>1: De-assert</p>                                  |
| 15:9           | /          | /           | /                                                                                                             |
| 8              | R/W        | 0x1         | <p>L2_RST<br/>Cluster L2 Cache Reset<br/>0: Assert<br/>1: De-assert</p>                                       |
| 7:4            | /          | /           | /                                                                                                             |
| 3:0            | R/W        | 0x1         | <p>CORE_RESET<br/>Cluster CPU[1:0] Reset Assert (The bit[3:2] is not used)<br/>0: Assert<br/>1: De-assert</p> |

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

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

| Offset: 0x0010 |            |             | Register Name: C0_CTRL_REG0                                                                                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                           |
| 29             | R/W        | 0x0         | BROADCAST_OUTER<br>Enable broadcasting outer shareable transactions.<br>0: Outer Shareable transactions are not broadcasted externally.<br>1: Outer Shareable transactions are broadcasted externally.                                                |
| 28             | R/W        | 0x0         | BROADCAST_CACHE_MAINT<br>Enable broadcasting cache maintenance operations to downstream caches.<br>0: Cache maintenance operations are not broadcasted to downstream caches.<br>1: Cache maintenance operations are broadcasted to downstream caches. |
| 27:12          | /          | /           | /                                                                                                                                                                                                                                                     |
| 11:8           | R/W        | 0x0         | CP15S_DISABLE<br>Disable write access to some secure CP15 registers<br>The meaning of each bit:<br>0: Enable write access to CP15 register<br>1: Disable write access to CP15 register                                                                |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                     |
| 4              | R/W        | 0x0         | L2_RST_DISABLE<br>Disable automatic L2 cache invalidation at reset.<br>0: L2 cache is reset by hardware.<br>1: L2 cache is not reset by hardware.                                                                                                     |
| 3:0            | R/W        | 0x0         | L1_RST_DISABLE<br>Disable automatic Cluster CPU[1:0] L1 cache invalidation at reset.<br>(The bit[3:2] is not used)<br>0: L1 cache is reset by hardware.<br>1: L1 cache is not reset by hardware.                                                      |

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

| Offset: 0x0014 |            |             | Register Name: C0_CTRL_REG1 |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:2           | /          | /           | /                           |

| Offset: 0x0014 |            |             | Register Name: C0_CTRL_REG1                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 1              | R/W        | 0x0         | CRM_LowFreq_AutoSelect<br>Enable CRM to automatically select low frequency.<br>0: Disabled<br>1: Enabled                                |
| 0              | R/W        | 0x0         | ACINACTM<br>Deactivate snoop interface<br>0: Snoop interface is active<br>1: Snoop interface is inactive and no longer accepts requests |

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

| Offset: 0x0018 |            |             | Register Name: C0_CTRL_REG2                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:25          | /          | /           | /                                                                                                                                                        |
| 24             | R/W        | 0x0         | EVENTI<br>Event input for processor to wake up from WFE state. This bit must remain high for at least one clock cycle to be visible by the cores.        |
| 23:20          | R/W        | 0x0         | EXM_CLR[1:0]<br>Clear the status of the corresponding interface. (The bit[23:22] is not used)<br>The meaning of each bit:<br>0: Not to clear<br>1: Clear |
| 19:0           | /          | /           |                                                                                                                                                          |

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

| Offset: 0x0024 |            |             | Register Name: CACHE_CFG_REG                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:22          | /          | /           | /                                                                         |
| 21:19          | R/W        | 0x3         | EMA_L2D<br>Indicates the port number of L2 Cache SRAM EMA control port.   |
| 18:17          | R/W        | 0x0         | EMAW_L2D<br>Indicates the port number of L2 Cache SRAM EMAW control port. |

| Offset: 0x0024 |            |             | Register Name: CACHE_CFG_REG                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 16             | R/W        | 0x0         | EMAS_L2D<br>Indicates the port number of L2 Cache SRAM EMAS control port. |
| 15:12          | /          | /           | /                                                                         |
| 11:8           | R/W        | 0x0         | DVS<br>FARADAY SRAM delay signal                                          |
| 7              | R/W        | 0x0         | DVSE<br>FARADAY SRAM delay enable signal                                  |
| 6              | R/W        | 0x0         | STOV                                                                      |
| 5:3            | R/W        | 0x3         | EMA<br>Indicates the port number of Cache SRAM EMA control port.          |
| 2:1            | R/W        | 0x1         | EMAW<br>Indicates the port number of Cache SRAM EMAW control port.        |
| 0              | R/W        | 0x0         | EMAS<br>Indicates the port number of Cache SRAM EMAS control port.        |

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

| Offset: 0x0080 |            |             | Register Name: C0_CPU_STATUS                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:28          | /          | /           | /                                                                                                                                                                                                   |
| 27:24          | R          | 0x0         | SMP_AMP<br>Configure the operating mode for CPU[1:0] as Symmetric Multiprocessing mode or Asymmetric Multiprocessing mode.<br>(The bit[27:26] is not used)<br>0: AMP mode<br>1: SMP mode            |
| 23:20          | /          | /           | /                                                                                                                                                                                                   |
| 19:16          | R          | 0xE         | STANDBYWFI<br>Indicates if CPU[1:0] of Cluster0 is in WFI standby mode.<br>(The bit[19:18] is not used)<br>0: The processor is not in WFI standby mode.<br>1: The processor is in WFI standby mode. |
| 15:12          | /          | /           | /                                                                                                                                                                                                   |

| Offset: 0x0080 |            |             | Register Name: C0_CPU_STATUS                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                    |
| 11:8           | R          | 0x0         | <p>STANDBYWFE</p> <p>Indicates if CPU[1:0] of Cluster0 is in the WFE standby mode.</p> <p>(The bit[11:10] is not used)</p> <p>0: The processor is not in WFE standby mode.</p> <p>1: The processor is in WFE standby mode.</p> |
| 7:1            | /          | /           | /                                                                                                                                                                                                                              |
| 0              | R          | 0x0         | <p>STANDBYWFI2</p> <p>Indicates if the L2 memory system of Cluster0 is in WFI standby mode.</p> <p>0: Cluster0_L2 is not in WFI standby mode.</p> <p>1: Cluster0_L2 is in WFI standby mode.</p>                                |

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

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

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

| Offset: 0x00C0 |            |             | Register Name: DBG_REG0                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                               |
| 31:12          | /          | /           | /                                                                                                                                                                                                                                         |
| 11:8           | R/W        | 0x0         | <p>DBGRESTART[1:0]</p> <p>Indicates if there are external restart requests for CPU[1:0].</p> <p>(The bit[11:10] is not used)</p> <p>The meaning of each bit:</p> <p>0: There are no such requests.</p> <p>1: There are such requests.</p> |
| 7:4            | /          | /           | /                                                                                                                                                                                                                                         |

| Offset: 0x00C0 |            |             | Register Name: DBG_REG0                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 3:0            | R/W        | 0xF         | <p>C_DBGPWRDUP</p> <p>Indicates if CPU[1:0] is powered-up.<br/>(The bit[3:2] is not used)</p> <p>The meaning of each bit:</p> <p>0: The core is powered down.</p> <p>1: The core is powered up.</p> |

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

| Offset: 0x00C4 |            |             | Register Name: DBG_REG1                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 15:12          | R/W        | 0x0         | <p>DBGRESTARTED[1:0] (The bit[15:14] is not used)</p> <p>Handshake for DBGRESTART.</p>                                                                                                                                                                               |
| 11:8           | /          | /           | /                                                                                                                                                                                                                                                                    |
| 7:4            | R          | 0x0         | <p>C_DBGNOPWRDWN</p> <p>Do Not Power Down Request.</p> <p>Indicates if the debugger requests CPU[1:0] not to power down.<br/>(The bit[7:6] is not used)</p> <p>The meaning of each bit:</p> <p>0: There are no such requests.</p> <p>1: There are such requests.</p> |
| 3:0            | R          | 0x0         | <p>C_DBGPWRUPREQ</p> <p>Power Up Request.</p> <p>Indicates if the debugger requests CPU[1:0] to power up.<br/>(The bit[3:2] is not used)</p> <p>The meaning of each bit:</p> <p>0: There are no such requests.</p> <p>1: There are such requests.</p>                |

### 3.2.4.10 0x00D0 CPU AXI Monitor Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: AXI_MNT_CTRL_REG                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:2           | /          | /           | /                                                                                                                                          |
| 1              | R/W        | 0x0         | AXI_MONITOR function clear<br>0: Not to clear<br>1: Clear the AXI_MONITOR related registers with the offset address from 0x00D8 to 0x00EC. |
| 0              | R/W        | 0x0         | Enable AXI_MONITOR function<br>0: Disabled<br>1: Enabled                                                                                   |

### 3.2.4.11 0x00D4 CPU AXI Monitor Period Register (Default Value: 0x0000\_0000)

| Offset: 0x00D4 |            |             | Register Name: AXI_MNT_PRD_REG                               |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:0           | R/W        | 0x0         | The monitoring period of AXI_MONITOR function (unit: cycles) |

### 3.2.4.12 0x00D8 CPU AXI Monitor Read Latency Register (Default Value: 0x0000\_0000)

| Offset: 0x00D8 |            |             | Register Name: AXI_MNT_RLTCY_REG                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | The total latency of AXI_MONITOR function read channel (unit: cycles) |

### 3.2.4.13 0x00DC CPU AXI Monitor Write Latency Register (Default Value: 0x0000\_0000)

| Offset: 0x00DC |            |             | Register Name: AXI_MNT_WLTCY_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | The total latency of AXI_MONITOR function write channel (unit: cycles) |

### 3.2.4.14 0x00E0 CPU AXI Monitor Read Request Register (Default Value: 0x0000\_0000)

| Offset: 0x00E0 |            |             | Register Name: AXI_MNT_RREQ_REG                                |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:0           | R          | 0x0         | The total times of AXI_MONITOR function read channel requests. |

### 3.2.4.15 0x00E4 CPU AXI Monitor Write Request Register (Default Value: 0x0000\_0000)

| Offset: 0x00E4 |            |             | Register Name: AXI_MNT_WREQ_REG                                 |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:0           | R          | 0x0         | The total times of AXI_MONITOR function write channel requests. |

### 3.2.4.16 0x00E8 CPU AXI Monitor Read Bandwidth Register (Default Value: 0x0000\_0000)

| Offset: 0x00E8 |            |             | Register Name: AXI_MNT_RBD_REG                                |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:0           | R          | 0x0         | The bandwidth of AXI_MONITOR function read channel (Unit: KB) |

### 3.2.4.17 0x00EC CPU AXI Monitor Write Bandwidth Register (Default Value: 0x0000\_0000)

| Offset: 0x00EC |            |             | Register Name: AXI_MNT_WBD_REG                                 |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:0           | R          | 0x0         | The bandwidth of AXI_MONITOR function write channel (Unit: KB) |

## 3.2.5 CPU Subsystem Control Register List

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

| Register Name     | Offset | Description                                |
|-------------------|--------|--------------------------------------------|
| GENER_CTRL_REG0   | 0x0000 | General Control Register0                  |
| GIC_JTAG_RST_CTRL | 0x000C | GIC and JTAG Reset Control Register        |
| C0_INT_EN         | 0x0010 | Cluster0 Interrupt Enable Control Register |

| Register Name   | Offset | Description               |
|-----------------|--------|---------------------------|
| IRQ_FIQ_STATUS  | 0x0014 | IRQ/FIQ Status Register   |
| GENER_CTRL_REG2 | 0x0018 | General Control Register2 |
| DBG_STATE       | 0x001C | Debug State Register      |

### 3.2.6 CPU Subsystem Control Register Description

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

| Offset: 0x0000 |            |             | Register Name: GENER_CTRL_REG0                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:3           | /          | /           | /                                                                                                                                                                                              |
| 2              | R/W        | 0x0         | Cluster 0 Corepll Select<br>Register width state<br>0: CCU clock<br>1: Disp PLL clock                                                                                                          |
| 1              | R/W        | 0x0         | IDC Clock Enable<br>0: IDC clock is disabled<br>1: IDC clock is enabled                                                                                                                        |
| 0              | R/W        | 0x0         | GIC_CFGSDISABLE<br>Disable write access to some secure GIC registers.<br>0: Write access to some secure GIC registers is enabled.<br>1: Write access to some secure GIC registers is disabled. |

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

| Offset: 0x000C |            |             | Register Name: GIC_JTAG_RST_CTRL                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:20          | /          | /           | /                                                                                     |
| 19:16          | R/W        | 0x0         | EXM_CLR[1:0] (The bit[19:18] is not used)<br>Clear the status of interface for debug. |
| 15:12          | /          | /           | /                                                                                     |

| Offset: 0x000C |            |             | Register Name: GIC_JTAG_RST_CTRL                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 11             | R/W        | 0x1         | CS_RST<br>CoreSight reset<br>0: Assert<br>1: De-assert                   |
| 10             | R/W        | 0x1         | DAP_RST<br>DAP reset<br>0: Assert<br>1: De-assert                        |
| 9              | R/W        | 0x1         | PORTRST<br>DAP reset signal control<br>0: Assert<br>1: De-assert         |
| 8              | R/W        | 0x1         | TRST<br>JTAG RTST signal<br>0: Assert<br>1: De-assert                    |
| 7:2            | /          | /           | /                                                                        |
| 1              | R/W        | 0x1         | IDC_RST<br>Interrupt delay controller reset<br>0: Assert<br>1: De-assert |
| 0              | R/W        | 0x1         | GIC_RST<br>GIC_reset_cpu_reg<br>0: Assert<br>1: De-assert                |

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

| Offset: 0x0010 |            |             | Register Name: C0_INT_EN |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:16          | /          | /           | /                        |

| Offset: 0x0010 |            |             | Register Name: C0_INT_EN                                                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
| 15:0           | R/W        | 0xFFFF      | <p>C0_GIC_EN</p> <p>Mask the FIQ_OUT[15:0] and IRQ_OUT[15:0] signals to system domain.</p> <p>The meaning of each bit:</p> <p>0: Mask the FIQ_OUT and IRQ_OUT signals to system domain.</p> <p>1: Not to mask the FIQ_OUT and IRQ_OUT signals to system domain.</p> |

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

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

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

| Offset: 0x0018 |            |             | Register Name: GENER_CTRL_REG2                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:17          | /          | /           | /                                                                                                                                            |
| 16             | R/W        | 0x0         | <p>CDBG_RSTACK</p> <p>Debug Reset ACK</p> <p>0: There are no debug reset ACKs.</p> <p>1: There are debug reset ACKs.</p>                     |
| 15:1           | /          | /           | /                                                                                                                                            |
| 0              | R/W        | 0x0         | <p>C0_TSCLKCHANGE</p> <p>Cluster 0 time stamp change.</p> <p>0: There are no time stamp changes.</p> <p>1: There are time stamp changes.</p> |

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

| Offset: 0x001C |            |             | Register Name: DBG_STATE                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:24          | R          | 0x0         | CLU_PWRSW_STA                                                                                             |
| 23:1           | /          | /           | /                                                                                                         |
| 0              | R          | 0x0         | C0_DBG_STATE<br>Indicates if Cluster0 is in debug mode or normal mode.<br>0: Normal mode<br>1: Debug mode |

### 3.3 Clock Controller Unit (CCU)

#### 3.3.1 Overview

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

The CCU includes the following features:

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

#### 3.3.2 Block Diagram

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

Figure 3-2 CCU Block Diagram



### 3.3.3 Functional Description

#### 3.3.3.1 System Bus Tree

The system buses include advanced high-performance buses (AHBs), advanced peripheral buses (APBs), and MBUS.

All devices mounted at the bus should use the related bus clocks, and the gating signals for the bus are from the CCU module.

The following figure shows the diagram of the System Bus Tree.

**Figure 3-3 System Bus Tree**



### 3.3.3.2 Module Clock Generation

The following figure describes module clock generation.

**Figure 3-4 Module Clock Generation**



### 3.3.3.3 PLL Distribution

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

**Figure 3-5 PLL Distribution**



Table 3-3 PLL Typical Application

| PLL Type         | Application Module                                                                                                                              | Notes                                           |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| PLL_CPUX         | ARM CPU, RISC-V CPU                                                                                                                             | Support DVFS                                    |
| PLL_DDR          | MBUS, DRAM                                                                                                                                      | Support spread spectrum<br>No support linear FM |
| PLL_PERI(2X)     | ARM CPU, DE, DI, G2D, CE, VE, DRAM, SMHCO1/2, SPI0/1, TCON_LCD, TCON_TV, TV Encoder, CSI, DSP                                                   | No support dynamic FM                           |
| PLL_PERI(1X)     | ARM CPU, PSI, APBO, APB1, CE, SMHCO1/2, SPI0/1, EMAC, IR_TX, I2S2_ASRC, TV Decoder, LEDC, DSI, CSI_MST, RISC-V CPU                              | No support dynamic FM                           |
| PLL_PERI(800M)   | SMHC2, ARM CPU, DRAM, RISC-V CPU                                                                                                                | No support dynamic FM                           |
| PLL_VIDEO0(4X)   | DE, DI, G2D, TCON_LCD, TCON_TV, TV Encoder                                                                                                      | No support DVFS                                 |
| PLL_VIDEO0(2X)   | DSI, CSI                                                                                                                                        | No support DVFS                                 |
| PLL_VIDEO0(1X)   | TCON_LCD, TCON_TV, TV Encoder, TV Decoder, CSI_MST                                                                                              | No support DVFS                                 |
| PLL_VIDEO1(4X)   | DE, DI, G2D, TCON_LCD, TCON_TV, TV Encoder                                                                                                      | No support DVFS                                 |
| PLL_VIDEO1(2X)   | DSI, CSI                                                                                                                                        | No support DVFS                                 |
| PLL_VIDEO1(1X)   | TCON_LCD, TCON_TV, TV Encoder, TV Decoder, CSI_MST                                                                                              | No support DVFS                                 |
| PLL_VE           | VE                                                                                                                                              | No support dynamic FM                           |
| PLL_AUDIO0 (1X)  | I2S1/2, OWA_TX, DMIC, AUDIO_CODEC, TPADC                                                                                                        | No support DVFS                                 |
| PLL_AUDIO0(4X)   | I2S1/2, I2S2_ASRC, OWA_TX                                                                                                                       | No support DVFS                                 |
| PLL_AUDIO1(DIV2) | DE, DI, G2D, DRAM, SMHCO1/2, SPI0/1, I2S1/2, I2S2_ASRC, OWA_TX, DMIC, AUDIO_CODEC, DSI, TCON_LCD, TCON_TV, TV Encoder, CSI_MST, DSP, RISC-V CPU | No support DVFS                                 |
| PLL_AUDIO1(DIV5) | SPI0/1, I2S1/2, I2S2_ASRC, OWA_TX, DMIC, AUDIO_CODEC, CSI_MST                                                                                   | No support DVFS                                 |

### 3.3.3.4 PLL Features

The following table shows the PLL features.

**Table 3-4 PLL Features**

| PLL            | Stable Frequency                          | Operating Frequency                                        | Actual Operating Frequency | Default Frequency                                                                                                     | Spread Spectrum | Linear FM | Rate Control | Pk-Pk                                                                                                   | Lock Time |
|----------------|-------------------------------------------|------------------------------------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------|-----------|--------------|---------------------------------------------------------------------------------------------------------|-----------|
| PLL_CPU        | 288 MHz to 3.0 GHz<br>(24*N)              | 288 MHz to 1.8 GHz                                         | 288 MHz to 1.8 GHz         | 408 MHz                                                                                                               | No              | Yes       | No           | < 200 ps                                                                                                | 1.5 ms    |
| PLL_AUDIO0     | 180 MHz to 3.0 GHz<br>(24MHz*N.x/M1/M0/P) | 24.576 MHz<br>22.5792 MHz<br>24.576*4 MHz<br>22.5792*4 MHz | 24.576 MHz                 | 24.576 MHz                                                                                                            | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_AUDIO1     | 180 MHz to 3.0 GHz                        | Fvco/Div<br>(Div: 1~8)                                     | Fvco/Div<br>(Div: 1~8)     | Integer mode:<br>1/2x: 1.536 GHz<br>1/5x: 614.4 MHz<br><br>Decimal mode:<br>1/2x: 1.1179648 GHz<br>1/5x: 471.8592 MHz | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_PERI       | 180 MHz to 3.2 GHz<br>(24*N/M1/M0)        | Fvco/Div<br>(Div:1~8)                                      | Fvco/Div<br>(Div:1~8)      | 1/2x: 1.2 GHz<br>1/3x: 800 MHz                                                                                        | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_Video0(4X) | 252 MHz to 3.0 GHz<br>(24*N/M)            | 192 MHz to 2400 MHz                                        | 192 MHz to 2400 MHz        | 1x: 297 MHz<br>2x: 594 MHz<br>4x: 1188 MHz                                                                            | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_Video1(4X) | 252 MHz to 3.0 GHz<br>(24*N/M)            | 192 MHz to 2400 MHz                                        | 192 MHz to 2400 MHz        | 1x: 297 MHz<br>2x: 594 MHz<br>4x: 1188 MHz                                                                            | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_VE         | 180 MHz to 3.0 GHz<br>(24*N/M1/M0)        | 192 MHz to 600 MHz                                         | 192 MHz to 600 MHz         | 432 MHz                                                                                                               | Yes             | No        | No           | < 200 ps                                                                                                | 500 us    |
| PLL_DDR        | 180 MHz to 3.0 GHz<br>(24*N/M1/M0)        | 192 MHz to 2.0 GHz                                         | 192 MHz to 2.0 GHz         | 432 MHz                                                                                                               | Yes             | No        | No           | 200 MHz to 800 MHz<br>(< 200 ps)<br>800 MHz to 1.3GHz<br>(< 140 ps)<br>1.3 GHz to 2.0 GHz<br>(< 100 ps) | 2 ms      |

### 3.3.4 Programming Guidelines

#### 3.3.4.1 Configuring the Frequency of PLL\_CPUX

The frequency configuration formula of PLL\_CPUX:

$$\text{PLL\_CPUX} = 24 \text{ MHz} * N/P$$

The parameter N is the frequency-doubling factor of PLL. The next parameter configuration can proceed after the PLL relock. The parameter P is a digital post-frequency-division factor, which can be dynamically switched in real-time, without affecting the normal work of PLL.



##### NOTE

PLL\_CPUX supports dynamic frequency adjustment (modifying the value of N). However, for the system stability, to configure the frequency of the PLL\_CPUX from a higher value to a lower one, switch the clock source of the CPU to another clock whose frequency is not higher than the current one first, and configure PLL\_CPUX to the target low frequency, and then switch the clock source of the CPU back to PLL\_CPUX.

Follow the steps below to adjust the frequency of PLL\_CPUX:

- Step 1** Before you configure PLL\_CPUX, switch the clock source of CPU to PLL\_PERI(1X).
- Step 2** Modify the parameters N and P of PLL\_CPUX.
- Step 3** Write the PLL Lock Enable bit (bit[29]) of [PLL\\_CPU\\_CTRL\\_REG](#) to 0 and then to 1.
- Step 4** Wait for the Lock bit (bit[28]) of [PLL\\_CPU\\_CTRL\\_REG](#) to change to 1.
- Step 5** Switch the clock source of the CPU to PLL\_CPUX.

#### 3.3.4.2 Configuring the Frequency of PLL\_AUDIO



##### NOTE

PLL\_AUDIO includes PLL\_AUDIO0 and PLL\_AUDIO1.

The frequency configuration formula of PLL\_AUDIO:

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

$$\text{PLL\_AUDIO1} = 24 \text{ MHz} * N/M$$

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

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

- Step 1** Configure the N, M0, M1 and P factors.
- Step 2** Configure [PLL\\_AUDIOx Control Register](#)[PLL\_SDM\_ENABLE] to 1.
- Step 3** Configure [PLL\\_AUDIOx Pattern0 Control Register](#) to enable the digital spread spectrum.
- Step 4** Write [PLL\\_AUDIOx Control Register](#)[Lock Enable] to 0 and then to 1.
- Step 5** Wait for [PLL\\_AUDIOx Control Register](#)[Lock] to 1.



#### NOTE

When the P factor of PLL\_AUDIO is an odd number, the clock output is an unequal-duty-cycle signal.

The recommended values for configuration factors of PLL\_AUDIO1 are as follows.

**Table 3-5 Recommended Values for Configuration Factors of PLL\_AUDIO1**

| Mode            | Clock Source (MHz) | Frequency-doubling N | VCO (MHz) | Post Frequency-Division | PLL Output (MHz) | Divisor | Actual Operating Frequency (MHz) | Description                                  |
|-----------------|--------------------|----------------------|-----------|-------------------------|------------------|---------|----------------------------------|----------------------------------------------|
| Integer divider | 24                 | 128                  | 3072      | 2                       | 1536             | 4       | 384                              | Provide clock source for peripherals         |
|                 |                    |                      |           |                         |                  | 8       | 192                              |                                              |
|                 |                    |                      |           |                         |                  | 16      | 96                               |                                              |
|                 |                    |                      |           |                         |                  | .....   |                                  |                                              |
|                 |                    |                      |           | 5                       | 614.4            | 25      | 24.576                           | For audio-related modules                    |
| Decimal divider | 24                 | 98.304               | 2359.296  | 2                       | 1179.648         | 2       | 589.824                          | Provides clock source for peripheral devices |
|                 |                    |                      |           |                         |                  | 3       | 393.216                          |                                              |
|                 |                    |                      |           |                         |                  | 6       | 196.608                          |                                              |
|                 |                    |                      |           |                         |                  | 12      | 98.304                           |                                              |

| Mode | Clock Source (MHz) | Frequency-doubling N | VCO (MHz) | Post Frequency-Division | PLL Output (MHz) | Divisor | Actual Operating Frequency (MHz) | Description               |
|------|--------------------|----------------------|-----------|-------------------------|------------------|---------|----------------------------------|---------------------------|
|      |                    |                      |           |                         |                  | 48      | 24.576                           | For audio-related modules |
|      |                    |                      |           | 5                       | 471.8592         |         |                                  |                           |

### 3.3.4.3 Configuring the Frequency of General PLLs

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

### 3.3.4.4 Enabling the PLL

Follow the steps below to enable the PLL:

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

### 3.3.4.5 Disabling the PLL

Follow the steps below to disable the PLL:

**Step 1** Write the PLL\_ENABLE bit (bit[31]) and the LDO\_EN bit of the PLL control register to 0.

**Step 2** Write the LOCK\_ENABLE bit (bit[29]) of the PLL control register to 0.



#### CAUTION

In the normal use of PLLs, it is unsuggested to enable and disable the PLLs frequently. Turning on and off the PLLs will cause mutual interference between PLLs, which will affect the stability of the system. When the clock is unnecessary, you can write 0 to the PLL\_OUTPUT\_EN bit of the PLL control register to disable the output gate of the PLL, instead of writing 0 to the Enable bit to disable the PLL.

### 3.3.4.6 Configuring Bus Clock

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

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

### 3.3.4.7 Configuring Module Clock

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

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

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

### 3.3.4.8 Implementing Spread Spectrum

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

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

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

Where,

P is the frequency division factor of module or PLL;

M0 is the post-frequency division factor of PLL;

M1 is the pre-frequency division factor of PLL;

N is the frequency doubling factor of PLL;

X is the amplitude coefficient of the spread spectrum.

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

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

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

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

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

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

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



#### NOTE

Different PLLs have different calculate formulas, refer to the CTRL register of the corresponding PLL in section 3.3.6 [Register Description](#).

## Configuration Procedure

Follow the steps below to implement the spread spectrum:

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

- a) Calculate the factor N and decimal value X according to the PLL frequency and PLL frequency formula. Refer to the control register of the corresponding PLL (named PLL\_xxx\_CTRL\_REG, where xxx is the module name) in 3.3.6 [Register Description](#) for the corresponding PLL frequency formula.
- b) Write M0, M1, N, and PLL frequency to the PLL control register.

- c) Configure the SDM\_Enable bit (bit[24]) of the PLL control register to 1 to enable the spread spectrum function.

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

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

### Step 3 Delay 20 us

#### Configuration Example

The following example shows how to configure the spread spectrum frequency as 605.3 MHz to 609.7 MHz.

If M1 = 0, M0 = 0, P = 1, according to the formula  $[f_1, f_2] = (N + 1 + [X_1, X_2]) \cdot 24\text{MHz}$ , you can get:

$$\begin{aligned} N + 1 + [X_1, X_2] &= \frac{[605.3, 609.7]}{24} \\ &= \frac{600 + [5.3, 9.7]}{24} \\ &= 24 + 1 + [5.3/24, 9.7/24] \end{aligned}$$

Obviously,

$$N = 24, X_1 = 5.3/24, X_2 = 9.7/24$$

$$\text{SDM_BOT} = 2^{17} * X_1 = 0x7111$$

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

If M0 = 1, M1=0, P = 1, then total frequency division factor is  $(M0 + 1) * 1 = 2$ , so the actual output frequency of PLL is 1212.1 MHz to 1219.4 MHz.

Similarly, you can get:

$$N = 49, X_1 = 12.1/24, X_2 = 19.4/24$$

Then calculate the values of SDM\_BOT and WAVE\_STEP according to the formulas, and follow the steps described in [Configuration Procedure](#).

### 3.3.5 Register List

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

| Register Name            | Offset | Description                          |
|--------------------------|--------|--------------------------------------|
| PLL_CPU_CTRL_REG         | 0x0000 | PLL_CPU Control Register             |
| PLL_DDR_CTRL_REG         | 0x0010 | PLL_DDR Control Register             |
| PLL_PERI_CTRL_REG        | 0x0020 | PLL_PERI Control Register            |
| PLL_VIDEO0_CTRL_REG      | 0x0040 | PLL_VIDEO0 Control Register          |
| PLL_VIDEO1_CTRL_REG      | 0x0048 | PLL_VIDEO1 Control Register          |
| PLL_VE_CTRL_REG          | 0x0058 | PLL_VE Control Register              |
| PLL_AUDIO0_CTRL_REG      | 0x0078 | PLL_AUDIO0 Control Register          |
| PLL_AUDIO1_CTRL_REG      | 0x0080 | PLL_AUDIO1 Control Register          |
| PLL_DDR_PATO_CTRL_REG    | 0x0110 | PLL_DDR Pattern0 Control Register    |
| PLL_DDR_PAT1_CTRL_REG    | 0x0114 | PLL_DDR Pattern1 Control Register    |
| PLL_PERI_PATO_CTRL_REG   | 0x0120 | PLL_PERI Pattern0 Control Register   |
| PLL_PERI_PAT1_CTRL_REG   | 0x0124 | PLL_PERI Pattern1 Control Register   |
| PLL_VIDEO0_PATO_CTRL_REG | 0x0140 | PLL_VIDEO0 Pattern0 Control Register |
| PLL_VIDEO0_PAT1_CTRL_REG | 0x0144 | PLL_VIDEO0 Pattern1 Control Register |
| PLL_VIDEO1_PATO_CTRL_REG | 0x0148 | PLL_VIDEO1 Pattern0 Control Register |
| PLL_VIDEO1_PAT1_CTRL_REG | 0x014C | PLL_VIDEO1 Pattern1 Control Register |
| PLL_VE_PATO_CTRL_REG     | 0x0158 | PLL_VE Pattern0 Control Register     |
| PLL_VE_PAT1_CTRL_REG     | 0x015C | PLL_VE Pattern1 Control Register     |
| PLL_AUDIO0_PATO_CTRL_REG | 0x0178 | PLL_AUDIO0 Pattern0 Control Register |
| PLL_AUDIO0_PAT1_CTRL_REG | 0x017C | PLL_AUDIO0 Pattern1 Control Register |
| PLL_AUDIO1_PATO_CTRL_REG | 0x0180 | PLL_AUDIO1 Pattern0 Control Register |
| PLL_AUDIO1_PAT1_CTRL_REG | 0x0184 | PLL_AUDIO1 Pattern1 Control Register |
| PLL_CPU_BIAS_REG         | 0x0300 | PLL_CPU Bias Register                |
| PLL_DDR_BIAS_REG         | 0x0310 | PLL_DDR Bias Register                |
| PLL_PERI_BIAS_REG        | 0x0320 | PLL_PERI Bias Register               |
| PLL_VIDEO0_BIAS_REG      | 0x0340 | PLL_VIDEO0 Bias Register             |
| PLL_VIDEO1_BIAS_REG      | 0x0348 | PLL_VIDEO1 Bias Register             |
| PLL_VE_BIAS_REG          | 0x0358 | PLL_VE Bias Register                 |
| PLL_AUDIO0_BIAS_REG      | 0x0378 | PLL_AUDIO0 Bias Register             |

| Register Name           | Offset | Description                        |
|-------------------------|--------|------------------------------------|
| PLL_AUDIO1_BIAS_REG     | 0x0380 | PLL_AUDIO1 Bias Register           |
| PLL_CPU_TUN_REG         | 0x0400 | PLL_CPU Tuning Register            |
| CPU_AXI_CFG_REG         | 0x0500 | CPU_AXI Configuration Register     |
| CPU_GATING_REG          | 0x0504 | CPU_GATING Configuration Register  |
| PSI_CLK_REG             | 0x0510 | PSI Clock Register                 |
| APB0_CLK_REG            | 0x0520 | APB0 Clock Register                |
| APB1_CLK_REG            | 0x0524 | APB1 Clock Register                |
| MBUS_CLK_REG            | 0x0540 | MBUS Clock Register                |
| DE_CLK_REG              | 0x0600 | DE Clock Register                  |
| DE_BGR_REG              | 0x060C | DE Bus Gating Reset Register       |
| DI_CLK_REG              | 0x0620 | DI Clock Register                  |
| DI_BGR_REG              | 0x062C | DI Bus Gating Reset Register       |
| G2D_CLK_REG             | 0x0630 | G2D Clock Register                 |
| G2D_BGR_REG             | 0x063C | G2D Bus Gating Reset Register      |
| CE_CLK_REG              | 0x0680 | CE Clock Register                  |
| CE_BGR_REG              | 0x068C | CE Bus Gating Reset Register       |
| VE_CLK_REG              | 0x0690 | VE Clock Register                  |
| VE_BGR_REG              | 0x069C | VE Bus Gating Reset Register       |
| DMA_BGR_REG             | 0x070C | DMA Bus Gating Reset Register      |
| MSGBOX_BGR_REG          | 0x071C | MSGBOX Bus Gating Reset Register   |
| SPINLOCK_BGR_REG        | 0x072C | SPINLOCK Bus Gating Reset Register |
| HSTIMER_BGR_REG         | 0x073C | HSTIMER Bus Gating Reset Register  |
| AVS_CLK_REG             | 0x0740 | AVS Clock Register                 |
| DBGSYS_BGR_REG          | 0x078C | DBGSYS Bus Gating Reset Register   |
| PWM_BGR_REG             | 0x07AC | PWM Bus Gating Reset Register      |
| IOMMU_BGR_REG           | 0x07BC | IOMMU Bus Gating Reset Register    |
| DRAM_CLK_REG            | 0x0800 | DRAM Clock Register                |
| MBUS_MAT_CLK_GATING_REG | 0x0804 | MBUS Master Clock Gating Register  |
| DRAM_BGR_REG            | 0x080C | DRAM Bus Gating Reset Register     |
| SMHCO_CLK_REG           | 0x0830 | SMHCO Clock Register               |
| SMHC1_CLK_REG           | 0x0834 | SMHC1 Clock Register               |
| SMHC2_CLK_REG           | 0x0838 | SMHC2 Clock Register               |
| SMHC_BGR_REG            | 0x084C | SMHC Bus Gating Reset Register     |
| UART_BGR_REG            | 0x090C | UART Bus Gating Reset Register     |

| Register Name           | Offset | Description                           |
|-------------------------|--------|---------------------------------------|
| TWI_BGR_REG             | 0x091C |                                       |
| SPI0_CLK_REG            | 0x0940 |                                       |
| SPI1_CLK_REG            | 0x0944 |                                       |
| SPI_BGR_REG             | 0x096C |                                       |
| EMAC_25M_CLK_REG        | 0x0970 | EMAC_25M Clock Register               |
| EMAC_BGR_REG            | 0x097C | EMAC Bus Gating Reset Register        |
| IRTX_CLK_REG            | 0x09C0 | IRTX Clock Register                   |
| IRTX_BGR_REG            | 0x09CC | IRTX Bus Gating Reset Register        |
| GPADC_BGR_REG           | 0x09EC | GPADC Bus Gating Reset Register       |
| THS_BGR_REG             | 0x09FC | THS Bus Gating Reset Register         |
| I2S1_CLK_REG            | 0x0A14 | I2S1 Clock Register                   |
| I2S2_CLK_REG            | 0x0A18 | I2S2 Clock Register                   |
| I2S2_ASRC_CLK_REG       | 0x0A1C | I2S2_ASRC Clock Register              |
| I2S_BGR_REG             | 0x0A20 | I2S Bus Gating Reset Register         |
| OWA_TX_CLK_REG          | 0x0A24 | OWA_TX Clock Register                 |
| OWA_BGR_REG             | 0x0A2C | OWA Bus Gating Reset Register         |
| DMIC_CLK_REG            | 0x0A40 | DMIC Clock Register                   |
| DMIC_BGR_REG            | 0x0A4C | DMIC Bus Gating Reset Register        |
| AUDIO_CODEC_DAC_CLK_REG | 0x0A50 | AUDIO_CODEC_DAC Clock Register        |
| AUDIO_CODEC_ADC_CLK_REG | 0x0A54 | AUDIO_CODEC_ADC Clock Register        |
| AUDIO_CODEC_BGR_REG     | 0x0A5C | AUDIO_CODEC Bus Gating Reset Register |
| USB0_CLK_REG            | 0x0A70 | USB0 Clock Register                   |
| USB1_CLK_REG            | 0x0A74 | USB1 Clock Register                   |
| USB_BGR_REG             | 0x0A8C | USB Bus Gating Reset Register         |
| DPSS_TOP_BGR_REG        | 0x0ABC | DPSS_TOP Bus Gating Reset Register    |
| DSI_CLK_REG             | 0x0B24 | DSI Clock Register                    |
| DSI_BGR_REG             | 0x0B4C | DSI Bus Gating Reset Register         |
| TCONLCD_CLK_REG         | 0x0B60 | TCONLCD Clock Register                |
| TCONLCD_BGR_REG         | 0x0B7C | TCONLCD Bus Gating Reset Register     |
| TCONTV_CLK_REG          | 0x0B80 | TCONTV Clock Register                 |
| TCONTV_BGR_REG          | 0x0B9C | TCONTV Bus Gating Reset Register      |
| LVDS_BGR_REG            | 0x0BAC | LVDS Bus Gating Reset Register        |
| TVE_CLK_REG             | 0x0BB0 | TVE Clock Register                    |
| TVE_BGR_REG             | 0x0BBC | TVE Bus Gating Reset Register         |

| Register Name         | Offset | Description                          |
|-----------------------|--------|--------------------------------------|
| TVD_CLK_REG           | 0x0BC0 | TVD Clock Register                   |
| TVD_BGR_REG           | 0x0BDC | TVD Bus Gating Reset Register        |
| LEDC_CLK_REG          | 0x0BF0 | LEDC Clock Register                  |
| LEDC_BGR_REG          | 0x0BFC | LEDC Bus Gating Reset Register       |
| CSI_CLK_REG           | 0x0C04 | CSI Clock Register                   |
| CSI_MASTER_CLK_REG    | 0x0C08 | CSI Master Clock Register            |
| CSI_BGR_REG           | 0x0C1C | CSI Bus Gating Reset Register        |
| TPADC_CLK_REG         | 0x0C50 | TPADC Clock Register                 |
| TPADC_BGR_REG         | 0x0C5C | TPADC Bus Gating Reset Register      |
| DSP_CLK_REG           | 0x0C70 | DSP Clock Register                   |
| DSP_BGR_REG           | 0x0C7C | DSP Bus Gating Reset Register        |
| RISC-V_CLK_REG        | 0x0D00 | RISC-V Clock Register                |
| RISC-V_GATING_REG     | 0x0D04 | RISC-V GATING Configuration Register |
| RISC-V_CFG_BGR_REG    | 0x0D0C | RISC-V_CFG Bus Gating Reset Register |
| PLL_LOCK_DBG_CTRL_REG | 0x0F04 | PLL Lock Debug Control Register      |
| FRE_DET_CTRL_REG      | 0x0F08 | Frequency Detect Control Register    |
| FRE_UP_LIM_REG        | 0x0F0C | Frequency Up Limit Register          |
| FRE_DOWN_LIM_REG      | 0x0F10 | Frequency Down Limit Register        |
| CCU_FAN_GATE_REG      | 0x0F30 | CCU FANOUT CLOCK GATE Register       |
| CLK27M_FAN_REG        | 0x0F34 | CLK27M FANOUT Register               |
| PCLK_FAN_REG          | 0x0F38 | PCLK FANOUT Register                 |
| CCU_FAN_REG           | 0x0F3C | CCU FANOUT Register                  |

### 3.3.6 Register Description

#### 3.3.6.1 0x0000 PLL\_CPU Control Register (Default Value: 0x4A00\_1000)

| Offset: 0x0000 |            |             | Register Name: PLL_CPU_CTRL_REG                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
| 31             | R/W        | 0x0         | <b>PLL_EN</b><br>PLL Enable<br>0: Disable<br>1: Enable<br>The PLL_CPU= InputFreq*N.<br><b>The PLL_CPU output frequency must be in the range from 200 MHz to 3 GHz. And the default value of PLL_CPUX is 408 MHz when the crystal oscillator is 24 MHz.</b> |
| 30             | R/W        | 0x1         | <b>PLL_LDO_EN</b><br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                 |
| 29             | R/W        | 0x0         | <b>LOCK_ENABLE</b><br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                               |
| 28             | R          | 0x0         | <b>LOCK</b><br>PLL Lock Status<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                                                                                    |
| 27             | R/W        | 0x1         | <b>PLL_OUTPUT_GATE</b><br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of the PLL.                                                                                                                  |
| 26:24          | R/W        | 0x2         | <b>PLL_LOCK_TIME</b> .<br>PLL Lock Time<br>The bit indicates the step amplitude from one frequency to another.                                                                                                                                             |
| 23:16          | /          | /           | /                                                                                                                                                                                                                                                          |

| Offset: 0x0000 |            |             | Register Name: PLL_CPU_CTRL_REG                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 15:8           | R/W        | 0x10        | <p>PLL_N</p> <p>PLL N</p> <p>N= PLL_N +1</p> <p>PLL_N is from 0 to 254.</p> <p>In application, PLL_N shall be more than or equal to 12.</p>     |
| 7:6            | R/W        | 0x0         | <p>PLL_UNLOCK_MDSEL</p> <p>PLL Unlock Level</p> <p>00: 21-29 Clock Cycles</p> <p>01: 22-28 Clock Cycles</p> <p>1X: 20-30 Clock Cycles</p>       |
| 5              | R/W        | 0x0         | <p>PLL_LOCK_MDSEL</p> <p>PLL Lock Level</p> <p>0: 24-26 Clock Cycles</p> <p>1: 23-27 Clock Cycles</p>                                           |
| 4:2            | /          | /           | /                                                                                                                                               |
| 1:0            | R/W        | 0x0         | <p>PLL_M</p> <p>PLL_M</p> <p>M = PLL_FACTOR_M + 1</p> <p>PLL_FACTOR_M is from 0 to 3.</p> <p><b>Note: The M factor is only for testing.</b></p> |

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

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

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

| Offset: 0x0010 |            |             | Register Name: PLL_DDR_CTRL_REG                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>$M1 = PLL\_INPUT\_DIV2 + 1$<br>PLL_INPUT_DIV2 is from 0 to 1.     |
| 0              | R/W        | 0x1         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>$M0 = PLL\_OUTPUT\_DIV2 + 1$<br>PLL_OUTPUT_DIV2 is from 0 to 1. |

### 3.3.6.3 0x0020 PLL\_PERI Control Register (Default Value: 0x4821\_6300)

| Offset: 0x0020 |            |             | Register Name: PLL_PERI_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>$PLL\_PERI(2X) = 24 \text{ MHz} * N / M / P0$<br>$PLL\_PERI(1X) = 24 \text{ MHz} * N / M / P0 / 2$<br>$PLL\_PERI(800M) = 24 \text{ MHz} * N / M / P1.$<br>When the crystal oscillator is 24 MHz, the default frequency of PLL_PERI(2X) is 1.2 GHz, the default frequency of PLL_PERI(1X) is 600 MHz, and the default frequency of PLL_PERI(800M) is 800 MHz.<br><b>The output clock of PLL_PERI(2X) is fixed to 1.2 GHz and not suggested to change the parameter.</b> |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Offset: 0x0020 |            |             | Register Name: PLL_PERI_CTRL_REG                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 28             | R          | 0x0         | <p>LOCK</p> <p>PLL Lock</p> <p>0: Unlocked</p> <p>1: Locked (It indicates that the PLL has been stable.)</p>                                          |
| 27             | R/W        | 0x1         | <p>PLL_OUTPUT_GATE</p> <p>PLL Output Gating Enable</p> <p>0: Disable</p> <p>1: Enable</p> <p>The bit is used to control the output enable of PLL.</p> |
| 26:25          | /          | /           | /                                                                                                                                                     |
| 24             | R/W        | 0x0         | <p>PLL_SDM_EN</p> <p>PLL_SDM Enable</p> <p>0: Disable</p> <p>1: Enable</p> <p>Enable spread spectrum and decimal division.</p>                        |
| 23             | /          | /           | /                                                                                                                                                     |
| 22:20          | R/W        | 0x2         | <p>PLL_P1</p> <p>PLL Output Div P1</p> <p>P1=PLL_OUTPUT_DIV_P1 + 1</p> <p>PLL_OUTPUT_DIV_P1 is from 0 to 7.</p>                                       |
| 19             | /          | /           | /                                                                                                                                                     |
| 18:16          | R/W        | 0x1         | <p>PLL_P0</p> <p>PLL Output Div P0</p> <p>P0=PLL_OUTPUT_DIV_P0 + 1</p> <p>PLL_OUTPUT_DIV_P0 is from 0 to 7.</p>                                       |
| 15:8           | R/W        | 0x63        | <p>PLL_N</p> <p>PLL N</p> <p>N= PLL_N +1</p> <p>PLL_N is from 0 to 254.</p> <p>In application, PLL_N shall be more than or equal to 12.</p>           |
| 7:6            | R/W        | 0x0         | <p>PLL_UNLOCK_MDSEL</p> <p>PLL Unlock Level</p> <p>00: 21-29 Clock Cycles</p> <p>01: 22-28 Clock Cycles</p> <p>1X: 20-30 Clock Cycles</p>             |

| Offset: 0x0020 |            |             | Register Name: PLL_PERI_CTRL_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles           |
| 4:2            | /          | /           | /                                                                                            |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M<br>M1=PLL_INPUT_DIV2 + 1<br>PLL_INPUT_DIV2 is from 0 to 1. |
| 0              | /          | /           | /                                                                                            |

### 3.3.6.4 0x0040 PLL\_VIDEO0 Control Register (Default Value: 0x4800\_6203)

| Offset: 0x0040 |            |             | Register Name: PLL_VIDEO0_CTRL_REG                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                           |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>For application,<br>$PLL\_VIDEO0(4X) = \text{InputFreq} * N/M.$<br>$PLL\_VIDEO0(2X) = \text{InputFreq} * N/M/2.$<br>$PLL\_VIDEO0(1X) = \text{InputFreq} * N/M/4.$<br>When the HOSC is 24 MHz, the default frequency of PLL_VIDEO0(4X) is 1188 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                   |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                 |

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

| Offset: 0x0040 |            |             | Register Name: PLL_VIDEO0_CTRL_REG                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 0              | R/W        | 0x1         | <p>PLL_OUTPUT_DIV2</p> <p>PLL Output Div D (The factor is only for testing)</p> <p>M0=PLL_OUTPUT_DIV_D + 1</p> <p>PLL_OUTPUT_DIV_D is from 0 to 1.</p> <p>For test, PLL_VIDEO0(4X) = 24MHz*N/M/D</p> |

### 3.3.6.5 0x0048 PLL\_VIDEO1 Control Register (Default Value: 0x4800\_6203)

| Offset: 0x0048 |            |             | Register Name: PLL_VIDEO1_CTRL_REG                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | <p>PLL_EN</p> <p>PLL Enable</p> <p>0: Disable</p> <p>1: Enable</p> <p>For application,</p> <p>PLL_VIDEO1(4X)=InputFreq *N/M.</p> <p>PLL_VIDEO1(2X)= InputFreq *N/M/2.</p> <p>PLL_VIDEO1(1X)= InputFreq*N/M/4.</p> <p>When the HOSC is 24 MHz, the default frequency of PLL_VIDEO1(4X) is 1188 MHz.</p> |
| 30             | R/W        | 0x1         | <p>PLL_LDO_EN</p> <p>LDO Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                                                                                                                 |
| 29             | R/W        | 0x0         | <p>LOCK_ENABLE</p> <p>Lock Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                                                                                                               |
| 28             | R          | 0x0         | <p>LOCK</p> <p>PLL Lock</p> <p>0: Unlocked</p> <p>1: Locked (It indicates that the PLL has been stable.)</p>                                                                                                                                                                                           |

| Offset: 0x0048 |            |             | Register Name: PLL_VIDEO1_CTRL_REG                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 27             | R/W        | 0x1         | <p>PLL_OUTPUT_GATE<br/>PLL Output Gating Enable<br/>0: Disable<br/>1: Enable<br/>The bit is used to control the output enable of PLL.</p>                                               |
| 26:25          | /          | /           | /                                                                                                                                                                                       |
| 24             | R/W        | 0x0         | <p>PLL_SDM_EN<br/>PLL SDM Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                       |
| 23:16          | /          | /           | /                                                                                                                                                                                       |
| 15:8           | R/W        | 0x62        | <p>PLL_FACTOR_N<br/>PLL FACTOR N<br/>N= PLL_FACTOR_N +1<br/>PLL_FACTOR_N is from 0 to 254.<br/>In application, PLL_FACTOR_N shall be more than or equal to 12.</p>                      |
| 7:6            | R/W        | 0x0         | <p>PLL_UNLOCK_MDSEL<br/>PLL Unlock Level<br/>00: 21-29 Clock Cycles<br/>01: 22-28 Clock Cycles<br/>1X: 20-30 Clock Cycles</p>                                                           |
| 5              | R/W        | 0x0         | <p>PLL_LOCK_MDSEL<br/>PLL Lock Level<br/>0: 24-26 Clock Cycles<br/>1: 23-27 Clock Cycles</p>                                                                                            |
| 4:2            | /          | /           | /                                                                                                                                                                                       |
| 1              | R/W        | 0x1         | <p>PLL_INPUT_DIV2<br/>PLL Input Div M<br/>M1=PLL_INPUT_DIV_M + 1<br/>PLL_INPUT_DIV_M is from 0 to 1.</p>                                                                                |
| 0              | R/W        | 0x1         | <p>PLL_OUTPUT_DIV2<br/>PLL Output Div D.(The factor is only for testing)<br/>M0=PLL_OUTPUT_DIV_D + 1<br/>PLL_OUTPUT_DIV_D is from 0 to 1.<br/>For test, PLL_VIDEO1(4X) =24MHz*N/M/D</p> |

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

| Offset: 0x0058 |            |             | Register Name: PLL_VE_CTRL_REG                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31             | R/W        | 0x0         | PLL_EN<br>PLL Enable<br>0: Disable<br>1: Enable<br>$\text{PLL\_VE} = \text{InputFreq} * N / M1 / M0.$<br>When the HOSC is 24 MHz, the default frequency of PLL_VE is 432 MHz. |
| 30             | R/W        | 0x1         | PLL_LDO_EN<br>LDO Enable<br>0: Disable<br>1: Enable                                                                                                                           |
| 29             | R/W        | 0x0         | LOCK_ENABLE<br>Lock Enable<br>0: Disable<br>1: Enable                                                                                                                         |
| 28             | R          | 0x0         | LOCK<br>PLL Lock<br>0: Unlocked<br>1: Locked (It indicates that the PLL has been stable.)                                                                                     |
| 27             | R/W        | 0x1         | PLL_OUTPUT_GATE<br>PLL Output Gating Enable<br>0: Disable<br>1: Enable<br>The bit is used to control the output enable of PLL.                                                |
| 26:25          | /          | /           | /                                                                                                                                                                             |
| 24             | R/W        | 0x0         | PLL_SDM_EN<br>PLL SDM Enable<br>0: Disable<br>1: Enable                                                                                                                       |
| 23:16          | /          | /           | /                                                                                                                                                                             |

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

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

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO0_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31             | R/W        | 0x0         | <p>PLL_EN<br/>PLL Enable<br/>0: Disable<br/>1: Enable</p> <p><math>\text{PLL\_AUDIO0(4X)} = 24\text{MHz} * \text{N} / \text{M1/M0/P}</math><br/> <math>\text{PLL\_AUDIO0(2X)} = (24\text{MHz} * \text{N}) / \text{M1/M0/P/2}</math><br/> <math>\text{PLL\_AUDIO0(1X)} = (24\text{MHz} * \text{N}) / \text{M1/M0/P/4}</math></p> <p><b>Note: <math>7.5 \leq \text{N/M0/M1} \leq 125</math> and <math>12 \leq \text{N}</math></b></p> <p>The working frequency range of <math>24\text{MHz} * \text{N/M0/M1}</math> is from 180 MHz to 3.0 GHz.</p> <p>The default frequency of PLL_AUDIO0(1X) is 24.5714 MHz.</p> |
| 30             | R/W        | 0x1         | <p>PLL_LDO_EN<br/>LDO Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 29             | R/W        | 0x0         | <p>LOCK_ENABLE<br/>Lock Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 28             | R          | 0x0         | <p>LOCK<br/>PLL Lock<br/>0: Unlocked<br/>1: Locked (It indicates that the PLL has been stable.)</p> <p><b>Note: The bit is only valid when the bit29 is set to 1.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27             | R/W        | 0x1         | <p>PLL_OUTPUT_GATE<br/>0: Disable<br/>1: Enable</p> <p>The bit is used to control the output enable of PLL.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24             | R/W        | 0x0         | <p>PLL_SDM_EN<br/>PLL SDM Enable<br/>0: Disable<br/>1: Enable</p> <p>Enable spread spectrum and decimal division.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0078 |            |             | Register Name: PLL_AUDIO0_CTRL_REG                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 21:16          | R/W        | 0x14        | PLL_P<br>PLL Post-div P<br>$P = \text{PLL\_POST\_DIV\_P} + 1$<br>PLL_POST_DIV_P is from 0 to 63.                                 |
| 15:8           | R/W        | 0x55        | PLL_N<br>PLL N<br>$N = \text{PLL\_N} + 1$<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 12. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles               |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                               |
| 4:2            | /          | /           | /                                                                                                                                |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M1<br>$M1 = \text{PLL\_INPUT\_DIV2} + 1$<br>PLL_INPUT_DIV2 is from 0 to 1.                       |
| 0              | R/W        | 0x0         | PLL_OUTPUT_DIV2<br>PLL Output Div M0<br>$M0 = \text{PLL\_OUTPUT\_DIV2} + 1$<br>PLL_OUTPUT_DIV2 is from 0 to 1.                   |

### 3.3.6.8 0x0080 PLL\_AUDIO1 Control Register (Default Value: 0x4841\_7F00)

| Offset: 0x0080 |            |             | Register Name: PLL_AUDIO1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | <p>PLL_EN<br/>PLL Enable<br/>0: Disable<br/>1: Enable</p> <p>PLL_AUDIO1 = 24MHz*N/M<br/>PLL_AUDIO1(DIV2) = 24MHz*N/M/P0<br/>PLL_AUDIO1(DIV5) = 24MHz*N/M/P1</p> <p>The working frequency range of 24 MHz/M*N is from 180 MHz to 3.5 GHz.</p> <p>The default frequency of PLL_AUDIO1 is 3072 MHz.<br/>The default frequency of PLL_AUDIO1(DIV2) is 1536 MHz.<br/>The default frequency of PLL_AUDIO1(DIV5) is 614.4 MHz (24.576 MHz*25).</p> |
| 30             | R/W        | 0x1         | <p>PLL_LDO_EN<br/>LDO Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                               |
| 29             | R/W        | 0x0         | <p>LOCK_ENABLE<br/>Lock Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 28             | R          | 0x0         | <p>LOCK<br/>0: Unlocked<br/>1: Locked (It indicates that the PLL has been stable.)</p> <p><b>Note: The bit is only valid when the bit29 is set to 1.</b></p>                                                                                                                                                                                                                                                                                |
| 27             | R/W        | 0x1         | <p>PLL_OUTPUT_GATE<br/>0: Disable<br/>1: Enable</p> <p>The bit is used to control the output enable of PLL.</p>                                                                                                                                                                                                                                                                                                                             |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 24             | R/W        | 0x0         | <p>PLL_SDM_EN<br/>0: Disable<br/>1: Enable</p> <p>Enable spread spectrum and decimal division.</p>                                                                                                                                                                                                                                                                                                                                          |
| 23             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0080 |            |             | Register Name: PLL_AUDIO1_CTRL_REG                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 22:20          | R/W        | 0x4         | PLL_P1<br>PLL Output Div P1<br>$P1 = \text{PLL\_OUTPUT\_DIV\_P1} + 1$<br>PLL_OUTPUT_DIV_P1 is from 0 to 7.                       |
| 19             | /          | /           | /                                                                                                                                |
| 18:16          | R/W        | 0x1         | PLL_P0<br>PLL Output Div P0<br>$P0 = \text{PLL\_OUTPUT\_DIV\_P0} + 1$<br>PLL_OUTPUT_DIV_P0 is from 0 to 7.                       |
| 15:8           | R/W        | 0x7F        | PLL_N<br>PLL N<br>$N = \text{PLL\_N} + 1$<br>PLL_N is from 0 to 254.<br>In application, PLL_N shall be more than or equal to 12. |
| 7:6            | R/W        | 0x0         | PLL_UNLOCK_MDSEL<br>PLL Unlock Level<br>00: 21-29 Clock Cycles<br>01: 22-28 Clock Cycles<br>1X: 20-30 Clock Cycles               |
| 5              | R/W        | 0x0         | PLL_LOCK_MDSEL<br>PLL Lock Level<br>0: 24-26 Clock Cycles<br>1: 23-27 Clock Cycles                                               |
| 4:2            | /          | /           | /                                                                                                                                |
| 1              | R/W        | 0x0         | PLL_INPUT_DIV2<br>PLL Input Div M<br>$M = \text{PLL\_INPUT\_DIV\_M} + 1$<br>PLL_INPUT_DIV_M is from 0 to 1.                      |
| 0              | /          | /           | /                                                                                                                                |

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

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

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

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

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

### 3.3.6.11 0x0120 PLL\_PERI Pattern0 Control Register (Default Value: 0x0000\_0000)

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

### 3.3.6.12 0x0124 PLL\_PERI Pattern1 Control Register (Default Value: 0x0000\_0000)

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

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

| Offset: 0x0140 |            |             | Register Name: PLL_VIDEO0_PAT0_CTRL_REG                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma-Delta Pattern Enable                                                                                         |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular(1-bit)<br>11: Triangular(n-bit)                      |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                                |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.</b> |

| Offset: 0x0140 |            |             | Register Name: PLL_VIDEO0_PATO_CTRL_REG                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                       |

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

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

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

| Offset: 0x0148 |            |             | Register Name: PLL_VIDEO1_PATO_CTRL_REG       |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma-Delta Pattern Enable |

| Offset: 0x0148 |            |             | Register Name: PLL_VIDEO1_PATO_CTRL_REG                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 30:29          | R/W        | 0x0         | <p>SPR_FREQ_MODE<br/>Spread Frequency Mode<br/>00: DC=0<br/>01: DC=1<br/>10: Triangular(1-bit)<br/>11: Triangular(n-bit)</p>                        |
| 28:20          | R/W        | 0x0         | <p>WAVE_STEP<br/>Wave Step</p>                                                                                                                      |
| 19             | R/W        | 0x0         | <p>SDM_CLK_SEL<br/>SDM Clock Select<br/>0: 24 MHz<br/>1: 12 MHz</p> <p><b>Note: When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.</b></p> |
| 18:17          | R/W        | 0x0         | <p>FREQ<br/>Frequency<br/>00: 31.5 kHz<br/>01: 32 kHz<br/>10: 32.5 kHz<br/>11: 33 kHz</p>                                                           |
| 16:0           | R/W        | 0x0         | <p>WAVE_BOT<br/>Wave Bottom</p>                                                                                                                     |

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

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

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

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

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

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

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

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

| Offset: 0x0178 |            |             | Register Name: PLL_AUDIO0_PAT0_CTRL_REG                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma-Delta Pattern Enable                                                                                         |
| 30:29          | R/W        | 0x0         | SPR_FREQ_MODE<br>Spread Frequency Mode<br>00: DC=0<br>01: DC=1<br>10: Triangular(1-bit)<br>11: Triangular(n-bit)                      |
| 28:20          | R/W        | 0x0         | WAVE_STEP<br>Wave Step                                                                                                                |
| 19             | R/W        | 0x0         | SDM_CLK_SEL<br>SDM Clock Select<br>0: 24 MHz<br>1: 12 MHz<br><b>Note: When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.</b> |

| Offset: 0x0178 |            |             | Register Name: PLL_AUDIO0_PAT0_CTRL_REG                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 18:17          | R/W        | 0x0         | FREQ<br>Frequency<br>00: 31.5 kHz<br>01: 32 kHz<br>10: 32.5 kHz<br>11: 33 kHz |
| 16:0           | R/W        | 0x0         | WAVE_BOT<br>Wave Bottom                                                       |

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

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

### 3.3.6.21 0x0180 PLL\_AUDIO1 Pattern0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0180 |            |             | Register Name: PLL_AUDIO1_PAT0_CTRL_REG       |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31             | R/W        | 0x0         | SIG_DELT_PAT_EN<br>Sigma-Delta Pattern Enable |

| Offset: 0x0180 |            |             | Register Name: PLL_AUDIO1_PAT0_CTRL_REG                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 30:29          | R/W        | 0x0         | <p>SPR_FREQ_MODE<br/>Spread Frequency Mode<br/>00: DC=0<br/>01: DC=1<br/>10: Triangular(1-bit)<br/>11: Triangular(n-bit)</p>                        |
| 28:20          | R/W        | 0x0         | <p>WAVE_STEP<br/>Wave Step</p>                                                                                                                      |
| 19             | R/W        | 0x0         | <p>SDM_CLK_SEL<br/>SDM Clock Select<br/>0: 24 MHz<br/>1: 12 MHz</p> <p><b>Note: When the PLL_INPUT_DIV2 is 1, the bit needs to be set to 1.</b></p> |
| 18:17          | R/W        | 0x0         | <p>FREQ<br/>Frequency<br/>00: 31.5 kHz<br/>01: 32 kHz<br/>10: 32.5 kHz<br/>11: 33 kHz</p>                                                           |
| 16:0           | R/W        | 0x0         | <p>WAVE_BOT<br/>Wave Bottom</p>                                                                                                                     |

### 3.3.6.22 0x0184 PLL\_AUDIO1 Pattern1 Control Register (Default Value: 0x0000\_0000)

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

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

### 3.3.6.23 0x0300 PLL\_CPU Bias Register (Default Value: 0x8010\_0000)

| Offset: 0x0300 |            |             | Register Name: PLL_CPU_BIAS_REG    |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31             | R/W        | 0x1         | PLL_VCO_RST_IN<br>VCO reset in     |
| 30:21          | /          | /           | /                                  |
| 20:16          | R/W        | 0x10        | PLL_CP<br>PLL current bias control |
| 15:0           | /          | /           | /                                  |

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

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

### 3.3.6.25 0x0320 PLL\_PERI Bias Register (Default Value: 0x0003\_0000)

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

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

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

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

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

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

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

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

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

| Offset: 0x0378 |            |             | Register Name: PLL_AUDIO0_BIAS_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 15:0           | /          | /           | /                                  |

### 3.3.6.30 0x0380 PLL\_AUDIO1 Bias Register (Default Value: 0x0003\_0000)

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

### 3.3.6.31 0x0400 PLL\_CPU Tuning Register (Default Value: 0x4440\_4000)

| Offset: 0x0400 |            |             | Register Name: PLL_CPU_TUN_REG          |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31             | /          | /           | /                                       |
| 30:28          | R/W        | 0x4         | PLL_VCO<br>VCO range control            |
| 27             | /          | /           | /                                       |
| 26:24          | R/W        | 0x4         | PLL_VCO_GAIN<br>KVCO gain control       |
| 23             | /          | /           | /                                       |
| 22:16          | R/W        | 0x40        | PLL_CNT_INT<br>Counter initial control  |
| 15             | R/W        | 0x0         | PLL_REG_OD<br>PLL-REG-OD0 for verify    |
| 14:8           | R/W        | 0x40        | PLL_B_IN<br>PLL-B-IN [6:0] for verify   |
| 7              | R/W        | 0x0         | PLL_REG_OD1<br>PLL-REG-OD1 for verify   |
| 6:0            | R          | 0x0         | PLL_B_OUT<br>PLL-B-OUT [6:0] for verify |

### 3.3.6.32 0x0500 CPU\_AXI Configuration Register (Default Value: 0x0000\_0301)

| Offset: 0x0500 |            |             | Register Name: CPU_AXI_CFG_REG                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                             |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                       |
| 26:24          | R/W        | 0x0         | <p>CPU_CLK_SEL<br/>Clock Source Select<br/>000: HOSC<br/>001: CLK32K<br/>010: CLK16M_RC<br/>011: PLL_CPU/P<br/>100: PLL_PERI(1X)<br/>101: PLL_PERI(2X)<br/>110: PLL_PERI(800M)<br/>CPU Clock = Clock Source<br/>CPU_AXI Clock = Clock Source/M</p> <p><b>Note:</b> The clock select is lack of glitch switching and supports dynamic configuration.</p> |
| 23:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                       |
| 17:16          | R/W        | 0x0         | <p>PLL_CPU_OUT_EXT_DIVP<br/>PLL Output External Divider P<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: /</p> <p>When the output clock is less than 288 MHz, the clock frequency can be get by dividing P.</p>                                                                                                                                                  |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                       |
| 9:8            | R/W        | 0x3         | <p>CPU_DIV2.<br/>Factor N (N = FACTOR_N +1)<br/>FACTOR_N is from 1 to 3.</p> <p><b>Note:</b> The clock division is lack of glitch switching and supports dynamic configuration.</p>                                                                                                                                                                     |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x0500 |            |             | Register Name: CPU_AXI_CFG_REG                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 1:0            | R/W        | 0x1         | CPU_DIV1.<br>Factor M (M= FACTOR_M +1)<br>FACTOR_M is from 1 to 3.<br><b>Note: The clock division is lack of glitch switching and supports dynamic configuration.</b> |

### 3.3.6.33 0x0504 CPU\_GATING Configuration Register (Default Value: 0x8000\_0000)

| Offset: 0x0504 |            |             | Register Name: CPU_GATING_REG                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31             | R/W        | 0x1         | CPU_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON                             |
| 30:16          | /          | /           | /                                                                                                   |
| 15:0           | W          | 0x0         | CPU_GATING_FIELD<br>CPU Gating Field<br>If CPU_GATING_FIELD==16'h16AA, the bit31 can be configured. |

### 3.3.6.34 0x0510 PSI Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0510 |            |             | Register Name: PSI_CLK_REG                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                           |
| 31:26          | /          | /           | /                                                                                                                                                                                                                                     |
| 25:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK32K<br>010: CLK16M_RC<br>011: PLL_PERI(1X)<br>PSI_CLK = Clock Source/M/N.<br><b>Note: The clock select is lack of glitch switching and supports dynamic configuration.</b> |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                     |

| Offset: 0x0510 |            |             | Register Name: PSI_CLK_REG                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N<br/>Factor N<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: 8</p> <p><b>Note:</b> The clock division is lack of glitch switching and supports dynamic configuration.</p>          |
| 7:2            | /          | /           | /                                                                                                                                                                                    |
| 1:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M.<br/>M= FACTOR_M +1<br/>FACTOR_M is from 0 to 3.</p> <p><b>Note:</b> The clock division is lack of glitch switching and supports dynamic configuration.</p> |

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

| Offset: 0x0520 |            |             | Register Name: APB0_CLK_REG                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                       |
| 31:26          | /          | /           | /                                                                                                                                                                                                                                                 |
| 25:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>00: HOSC<br/>01: CLK32K<br/>10: PSI_CLK<br/>11: PLL_PERI(1X)<br/>APB0_CLK = Clock Source/M/N.</p> <p><b>Note:</b> The clock select is lack of glitch switching and supports dynamic configuration.</p> |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                                 |

| Offset: 0x0520 |            |             | Register Name: APB0_CLK_REG                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N.</p> <p>Factor N</p> <p>00: 1</p> <p>01: 2</p> <p>10: 4</p> <p>11: 8</p> <p><b>Note: The clock division is lack of glitch switching and supports dynamic configuration.</b></p>   |
| 7:5            | /          | /           | /                                                                                                                                                                                             |
| 4:0            | R/W        | 0x0         | <p>FACTOR_M</p> <p>Factor M</p> <p>M = FACTOR_M+1</p> <p>FACTOR_M is from 0 to 31.</p> <p><b>Note: The clock division is lack of glitch switching and supports dynamic configuration.</b></p> |

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

| Offset: 0x0524 |            |             | Register Name: APB1_CLK_REG                                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
| 31:26          | /          | /           | /                                                                                                                                                                                                                                                                   |
| 25:24          | R/W        | 0x0         | <p>CLK_SRC_SEL</p> <p>Clock Source Select</p> <p>00: HOSC</p> <p>01: CLK32K</p> <p>10: PSI_CLK</p> <p>11: PLL_PERI(1X)</p> <p>APB1_CLK = Clock Source/M/N.</p> <p><b>Note: The clock select is lack of glitch switching and supports dynamic configuration.</b></p> |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                                                   |

| Offset: 0x0524 |            |             | Register Name: APB1_CLK_REG                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N<br/>Factor N<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: 8</p> <p><b>Note:</b> The clock division is lack of glitch switching and supports dynamic configuration.</p>                          |
| 7:5            | /          | /           | /                                                                                                                                                                                                    |
| 4:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/><math>M = FACTOR\_M + 1</math><br/>FACTOR_M is from 0 to 31.</p> <p><b>Note:</b> The clock division is lack of glitch switching and supports dynamic configuration.</p> |

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

| Offset: 0x0540 |            |             | Register Name: MBUS_CLK_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31             | /          | /           | /                                                             |
| 30             | R/W        | 0x1         | <p>MBUS_RST<br/>MBUS Reset<br/>0: Assert<br/>1: De-assert</p> |
| 29:0           | /          | /           | /                                                             |



#### NOTE

The MBUS clock is from the 4 frequency-division of PLL\_DDR, and it has the same source with the DRAM clock.

### 3.3.6.38 0x0600 DE Clock Register (Default Value: 0xC000\_0000)

| Offset: 0x0600 |            |             | Register Name: DE_CLK_REG                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | DE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DE_CLK = Clock Source/M                                  |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_PERI(2X)<br>001: PLL_VIDEO0(4X)<br>010: PLL_VIDEO1(4X)<br>011: PLL_AUDIO1(DIV2) |
| 23:5           | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                             |

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

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

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

| Offset: 0x0620 |            |             | Register Name: DI_CLK_REG                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | DI_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DI_CLK = Clock Source/M                                  |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_PERI(2X)<br>001: PLL_VIDEO0(4X)<br>010: PLL_VIDEO1(4X)<br>011: PLL_AUDIO1(DIV2) |
| 23:5           | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M = FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                            |

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

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

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

| Offset: 0x0630 |            |             | Register Name: G2D_CLK_REG                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | G2D_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>G2D_CLK = Clock Source/M.                               |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_PERI(2X)<br>001: PLL_VIDEO0(4X)<br>010: PLL_VIDEO1(4X)<br>011: PLL_AUDIO1(DIV2) |
| 23:5           | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31                                                             |

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

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

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

| Offset: 0x0680 |            |             | Register Name: CE_CLK_REG                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31             | R/W        | 0x0         | CE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CE_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: HOSC<br>01: PLL_PERI(2X)<br>10: PLL_PERI(1X)           |
| 23:10          | /          | /           | /                                                                                                |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                         |
| 7:4            | /          | /           | /                                                                                                |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                              |

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

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

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

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

| Offset: 0x0690 |            |             | Register Name: VE_CLK_REG                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31             | R/W        | 0x0         | VE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>VE_CLK = Clock Source/M. |
| 30:25          | /          | /           | /                                                                                              |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: PLL_VE<br>1: PLL_PERI(2X)                             |
| 23:5           | /          | /           | /                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                            |

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

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

| Offset: 0x069C |            |             | Register Name: VE_BGR_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 16             | R/W        | 0x0         | VE_RST<br>VE Reset For VE_PROT<br>0: Assert<br>1: DE-assert |
| 15:1           | /          | /           | /                                                           |
| 0              | R/W        | 0x0         | VE_GATING<br>Gating Clock For VE_PROT<br>0: Mask<br>1: Pass |

### 3.3.6.48 0x070C DMA Bus Gating Reset Register (Default Value: 0x0000\_0000)

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

**Note: The working clock is from PSI\_CLK.**

### 3.3.6.49 0x071C MSGBOX Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x071C |            |             | Register Name: MSGBOX_BGR_REG |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:19          | /          | /           | /                             |

| Offset: 0x071C |            |             | Register Name: MSGBOX_BGR_REG                                          |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 18             | R/W        | 0x0         | MSGBOX2_RST<br>RISC-V MSGBOX Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | MSGBOX1_RST<br>DSP MSGBOX Reset<br>0: Assert<br>1: De-assert           |
| 16             | R/W        | 0x0         | MSGBOX0_RST<br>CPU MSGBOX Reset<br>0: Assert<br>1: De-assert           |
| 15:3           | /          | /           | /                                                                      |
| 2              | R/W        | 0x0         | MSGBOX2_GATING<br>Gating Clock for RISC-V MSGBOX<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | MSGBOX1_GATING<br>Gating Clock for DSP MSGBOX<br>0: Mask<br>1: Pass    |
| 0              | R/W        | 0x0         | MSGBOX0_GATING<br>Gating Clock for CPU MSGBOX<br>0: Mask<br>1: Pass    |

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

| Offset: 0x072C |            |             | Register Name: SPINLOCK_BGR_REG                             |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:17          | /          | /           | /                                                           |
| 16             | R/W        | 0x0         | SPINLOCK_RST<br>SPINLOCK Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x072C |            |             | Register Name: SPINLOCK_BGR_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x0         | SPINLOCK_GATING<br>Gating Clock For SPINLOCK<br>0: Mask<br>1: Pass |

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

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

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

| Offset: 0x0740 |            |             | Register Name: AVS_CLK_REG                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31             | R/W        | 0x0         | AVS_CLK_GATING<br>Gating Clock<br>The AVS_CLK is from HOSC.<br>0: Clock is OFF<br>1: Clock is ON |
| 30:0           | /          | /           | /                                                                                                |

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

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

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

| Offset: 0x07AC |            |             | Register Name: PWM_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | PWM_RST<br>PWM Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | PWM_GATING<br>Gating Clock for PWM<br>0: Mask<br>1: Pass |

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

| Offset: 0x07BC |            |             | Register Name: IOMMU_BGR_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:1           | /          | /           | /                            |

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

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

| Offset: 0x0800 |            |             | Register Name: DRAM_CLK_REG                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0x1         | <p>DRAM_CLK_GATING</p> <p>Gating Clock</p> <p>DRAM_CLK = Clock Source/M/N.</p> <p>0: Clock is OFF</p> <p>1: Clock is ON</p>                                                                                                                                                                                         |
| 30:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 27             | R/WAC      | 0x0         | <p>SDRCLK_UPD</p> <p>SDRCLK Configuration 0 Update</p> <p>0: Invalid</p> <p>1: Valid</p> <p>Setting 1 will validate the bit. It will be automatically cleared after the bit is valid.</p> <p>Here supports dram req/ack signal. When dram_update is set to 1, dram_clk_sel/dram_div2/dram_clk1 will be updated.</p> |
| 26:24          | R/W        | 0x0         | <p>DRAM_CLK_SEL</p> <p>Clock Source Select</p> <p>00: PLL_DDR</p> <p>01: PLL_AUDIO1(DIV2)</p> <p>10: PLL_PERI(2X)</p> <p>11: PLL_PERI(800M)</p> <p><b>Note: The clock select is lack of glitch switching and supports dynamic configuration.</b></p>                                                                |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0800 |            |             | Register Name: DRAM_CLK_REG                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 9:8            | R/W        | 0x0         | DRAM_DIV2<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                              |
| 7:2            | /          | /           | /                                                                                                                                                                      |
| 1:0            | R/W        | 0x0         | DRAM_DIV1<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 3.<br><b>Note: The clock division is lack of glitch switching and supports dynamic configuration.</b> |

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

| Offset: 0x0804 |            |             | Register Name: MBUS_MAT_CLK_GATING_REG                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:12          | /          | /           | /                                                                    |
| 11             | R/W        | 0x0         | RISC-V_MCLK_EN<br>Gating MBUS Clock For RISC-V<br>0: Mask<br>1: Pass |
| 10             | R/W        | 0x0         | G2D_MCLK_EN<br>Gating MBUS Clock For G2D<br>0: Mask<br>1: Pass       |
| 9              | /          | /           | /                                                                    |
| 8              | R/W        | 0x0         | CSI_MCLK_EN<br>Gating MBUS Clock For CSI<br>0: Mask<br>1: Pass       |

| Offset: 0x0804 |            |             | Register Name: MBUS_MAT_CLK_GATING_REG                           |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 7              | R/W        | 0x0         | TVIN_MCLK_EN<br>Gating MBUS Clock For TVIN<br>0: Mask<br>1: Pass |
| 6:3            | /          | /           | /                                                                |
| 2              | R/W        | 0x0         | CE_MCLK_EN<br>Gating MBUS Clock For CE<br>0: Mask<br>1: Pass     |
| 1              | R/W        | 0x0         | VE_MCLK_EN<br>Gating MBUS Clock For VE<br>0: Mask<br>1: Pass     |
| 0              | R/W        | 0x0         | DMA_MCLK_EN<br>Gating MBUS Clock For DMA<br>0: Mask<br>1: Pass   |

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

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

**3.3.6.59 0x0830 SMHC0 Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0830 |            |             | Register Name: SMHC0_CLK_REG                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 31             | R/W        | 0x0         | SMHC0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SMHC0_CLK = Clock Source/M/N.                                 |
| 30:27          | /          | /           | /                                                                                                                                      |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_PERI(1X)<br>010: PLL_PERI(2X)<br>011: PLL_AUDIO1(DIV2)<br>Others: Reserved |
| 23:10          | /          | /           | /                                                                                                                                      |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                               |
| 7:4            | /          | /           | /                                                                                                                                      |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = FACTOR\_M + 1$<br>FACTOR_M is from 0 to 15.                                                               |

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

| Offset: 0x0834 |            |             | Register Name: SMHC1_CLK_REG                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 31             | R/W        | 0x0         | SMHC1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N                                       |
| 30:27          | /          | /           | /                                                                                                                                      |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_PERI(1X)<br>010: PLL_PERI(2X)<br>011: PLL_AUDIO1(DIV2)<br>Others: Reserved |
| 23:10          | /          | /           | /                                                                                                                                      |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                               |
| 7:4            | /          | /           | /                                                                                                                                      |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = FACTOR\_M + 1$<br>FACTOR_M is from 0 to 15.                                                               |

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

| Offset: 0x0838 |            |             | Register Name: SMHC2_CLK_REG                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31             | R/W        | 0x0         | SMHC2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N                                                              |
| 30:27          | /          | /           | /                                                                                                                                                             |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_PERI(1X)<br>010: PLL_PERI(2X)<br>011: PLL_PERI(800M)<br>100: PLL_AUDIO1(DIV2)<br>Others: Reserved |
| 23:10          | /          | /           | /                                                                                                                                                             |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                      |
| 7:4            | /          | /           | /                                                                                                                                                             |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                                                                           |

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

| Offset: 0x084C |            |             | Register Name: SMHC_BGR_REG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:19          | /          | /           | /                           |

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

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



#### NOTE

The clock of the UART is from APB1.

| Offset: 0x090C |            |             | Register Name: UART_BGR_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:22          | /          | /           | /                                                            |
| 21             | R/W        | 0x0         | UART5_RST<br>UART5 Reset<br>0: Assert<br>1: De-assert        |
| 20             | R/W        | 0x0         | UART4_RST<br>UART4 Reset<br>0: Assert<br>1: De-assert        |
| 19             | R/W        | 0x0         | UART3_RST<br>UART3 Reset<br>0: Assert<br>1: De-assert        |
| 18             | R/W        | 0x0         | UART2_RST<br>UART2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | UART1_RST<br>UART1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | UART0_RST<br>UART0 Reset<br>0: Assert<br>1: De-assert        |
| 15:6           | /          | /           | /                                                            |
| 5              | R/W        | 0x0         | UART5_GATING<br>Gating Clock for UART5<br>0: Mask<br>1: Pass |
| 4              | R/W        | 0x0         | UART4_GATING<br>Gating Clock for UART4<br>0: Mask<br>1: Pass |

| Offset: 0x090C |            |             | Register Name: UART_BGR_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 3              | R/W        | 0x0         | UART3_GATING<br>Gating Clock for UART3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | UART2_GATING<br>Gating Clock for UART2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | UART1_GATING<br>Gating Clock for UART1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | UART0_GATING<br>Gating Clock for UART0<br>0: Mask<br>1: Pass |

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


**NOTE**

The clock of the TWI is from APB1.

| Offset: 0x091C |            |             | Register Name: TWI_BGR_REG                          |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:20          | /          | /           | /                                                   |
| 19             | R/W        | 0x0         | TWI3_RST<br>TWI3 Reset<br>0: Assert<br>1: De-assert |
| 18             | R/W        | 0x0         | TWI2_RST<br>TWI2 Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x091C |            |             | Register Name: TWI_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 17             | R/W        | 0x0         | TWI1_RST<br>TWI1 Reset<br>0: Assert<br>1: De-assert        |
| 16             | R/W        | 0x0         | TWI0_RST<br>TWI0 Reset<br>0: Assert<br>1: De-assert        |
| 15:4           | /          | /           | /                                                          |
| 3              | R/W        | 0x0         | TWI3_GATING<br>Gating Clock for TWI3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | TWI2_GATING<br>Gating Clock for TWI2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | TWI1_GATING<br>Gating Clock for TWI1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | TWI0_GATING<br>Gating Clock for TWI0<br>0: Mask<br>1: Pass |

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

| Offset: 0x0940 |            |             | Register Name: SPI0_CLK_REG                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31             | R/W        | 0x0         | SPI0_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N. |

| Offset: 0x0940 |            |             | Register Name: SPI0_CLK_REG                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 30:27          | /          | /           | /                                                                                                                                                                             |
| 26:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>000: HOSC<br/>001: PLL_PERI(1X)<br/>010: PLL_PERI(2X)<br/>011: PLL_AUDIO1(DIV2)<br/>100: PLL_AUDIO1(DIV5)<br/>Others: Reserved</p> |
| 23:10          | /          | /           | /                                                                                                                                                                             |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N<br/>Factor N<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: 8</p>                                                                                                          |
| 7:4            | /          | /           | /                                                                                                                                                                             |
| 3:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/><math>M = FACTOR\_M + 1</math><br/>FACTOR_M is from 0 to 15.</p>                                                                                 |

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

| Offset: 0x0944 |            |             | Register Name: SPI1_CLK_REG                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31             | R/W        | 0x0         | <p>SCLK_GATING<br/>Gating Special Clock<br/>0: Clock is OFF<br/>1: Clock is ON<br/>SCLK = Clock Source/M/N.</p> |
| 30:27          | /          | /           | /                                                                                                               |

| Offset: 0x0944 |            |             | Register Name: SPI1_CLK_REG                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_PERI(1X)<br>010: PLL_PERI(2X)<br>011: PLL_AUDIO1(DIV2)<br>100: PLL_AUDIO1(DIV5)<br>Others: / |
| 23:10          | /          | /           | /                                                                                                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor_N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                 |
| 7:4            | /          | /           | /                                                                                                                                                        |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = \text{FACTOR\_M} + 1$<br>FACTOR_M is from 0 to 15.                                                                          |

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

| Offset: 0x096C |            |             | Register Name: SPI_BGR_REG                          |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:18          | /          | /           | /                                                   |
| 17             | R/W        | 0x0         | SPI1_RST<br>SPI1 Reset<br>0: Assert<br>1: De-assert |
| 16             | R/W        | 0x0         | SPI0_RST<br>SPI0 Reset<br>0: Assert<br>1: De-assert |
| 15:2           | /          | /           | /                                                   |

| Offset: 0x096C |            |             | Register Name: SPI_BGR_REG                                 |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 1              | R/W        | 0x0         | SPI1_GATING<br>Gating Clock for SPI1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | SPI0_GATING<br>Gating Clock for SPI0<br>0: Mask<br>1: Pass |

### 3.3.6.68 0x0970 EMAC\_25M Clock Register (Default: 0x0000\_0000)

| Offset: 0x0970 |            |             | Register Name: EMAC_25M_CLK_REG                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31             | R/W        | 0x0         | EMAC_25M_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CLK = PLL_PERI(1X)/24 = 25 MHz                      |
| 30             | R/W        | 0x0         | EMAC_25M_CLK_SRC_GATING<br>Gating the Source Clock of Special Clock<br>It is for low power design.<br>0: Clock is OFF<br>1: Clock is ON |
| 29:0           | /          | /           | /                                                                                                                                       |

### 3.3.6.69 0x097C EMAC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x097C |            |             | Register Name: EMAC_BGR_REG                         |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:17          | /          | /           | /                                                   |
| 16             | R/W        | 0x0         | EMAC_RST<br>EMAC Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x097C |            |             | Register Name: EMAC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | EMAC_GATING<br>Gating Clock for EMAC<br>0: Mask<br>1: Pass |

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

| Offset: 0x09C0 |            |             | Register Name: IRTX_CLK_REG                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31             | R/W        | 0x0         | IRTX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>IRTX_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                    |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: HOSC<br>1: PLL_PERI(1X)                                     |
| 23:10          | /          | /           | /                                                                                                    |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                             |
| 7:4            | /          | /           | /                                                                                                    |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                  |

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

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

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

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

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

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

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

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

| Offset: 0x0A14 |            |             | Register Name: I2S/PCM1_CLK_REG                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | I2S/PCM1_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S/PCM1_CLK = Clock Source/M/N.                   |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO0(4X)<br>10: PLL_AUDIO1(DIV2)<br>11: PLL_AUDIO1(DIV5) |
| 23:10          | /          | /           | /                                                                                                                              |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                                   |
| 7:5            | /          | /           | /                                                                                                                              |

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

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

| Offset: 0x0A18 |            |             | Register Name: I2S/PCM2_CLK_REG                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | I2S/PCM2_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S/PCM2_CLK = Clock Source/M/N.                   |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO0(4X)<br>10: PLL_AUDIO1(DIV2)<br>11: PLL_AUDIO1(DIV5) |
| 23:10          | /          | /           | /                                                                                                                              |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                                   |
| 7:5            | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                            |

### 3.3.6.76 0x0A1C I2S/PCM2\_ASRC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A1C |            |             | Register Name: I2S/PCM2_ASRC_CLK_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31             | R/W        | 0x0         | I2S/PCM2_ASRC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>I2S/PCM2_ASRC_CLK = Clock Source/M/N.       |
| 30:27          | /          | /           | /                                                                                                                            |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO0(4X)<br>01: PLL_PERI(1X)<br>10: PLL_AUDIO1(DIV2)<br>11: PLL_AUDIO1(DIV5) |
| 23:10          | /          | /           | /                                                                                                                            |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                                 |
| 7:5            | /          | /           | /                                                                                                                            |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = FACTOR\_M + 1$<br>FACTOR_M is from 0 to 31.                                                     |

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

| Offset: 0x0A20 |            |             | Register Name: I2S/PCM_BGR_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:19          | /          | /           | /                              |

| Offset: 0x0A20 |            |             | Register Name: I2S/PCM_BGR_REG                                     |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 18             | R/W        | 0x0         | I2S/PCM2_RST<br>I2S/PCM2 Reset<br>0: Assert<br>1: De-assert        |
| 17             | R/W        | 0x0         | I2S/PCM1_RST<br>I2S/PCM1 Reset<br>0: Assert<br>1: De-assert        |
| 16:3           | /          | /           | /                                                                  |
| 2              | R/W        | 0x0         | I2S/PCM2_GATING<br>Gating Clock for I2S/PCM2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | I2S/PCM1_GATING<br>Gating Clock for I2S/PCM1<br>0: Mask<br>1: Pass |
| 0              | /          | /           | /                                                                  |

### 3.3.6.78 0x0A24 OWA\_TX Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A24 |            |             | Register Name: OWA_TX_CLK_REG                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | OWA_TX_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>OWA_TX_CLK = Clock Source/M/N.                       |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO0(4X)<br>10: PLL_AUDIO1(DIV2)<br>11: PLL_AUDIO1(DIV5) |

| Offset: 0x0A24 |            |             | Register Name: OWA_TX_CLK_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 23:10          | /          | /           | /                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8             |
| 7:5            | /          | /           | /                                                                        |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = FACTOR\_M + 1$<br>FACTOR_M is from 0 to 31. |

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

| Offset: 0x0A2C |            |             | Register Name: OWA_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | OWA_RST<br>OWA Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | OWA_GATING<br>Gating Clock for OWA<br>0: Mask<br>1: Pass |

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

| Offset: 0x0A40 |            |             | Register Name: DMIC_CLK_REG                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31             | R/W        | 0x0         | DMIC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DMIC_CLK = Clock Source/M/N.     |
| 30:27          | /          | /           | /                                                                                                        |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO1(DIV2)<br>10: PLL_AUDIO1(DIV5) |
| 23:10          | /          | /           | /                                                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                             |
| 7:5            | /          | /           | /                                                                                                        |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                      |

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

| Offset: 0x0A4C |            |             | Register Name: DMIC_BGR_REG                         |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:17          | /          | /           | /                                                   |
| 16             | R/W        | 0x0         | DMIC_RST<br>DMIC Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x0A4C |            |             | Register Name: DMIC_BGR_REG                                |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 15:1           | /          | /           | /                                                          |
| 0              | R/W        | 0x0         | DMIC_GATING<br>Gating Clock for DMIC<br>0: Mask<br>1: Pass |

### 3.3.6.82 0x0A50 AUDIO\_CODEC\_DAC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A50 |            |             | Register Name: AUDIO_CODEC_DAC_CLK_REG                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31             | R/W        | 0x0         | AUDIO_CODEC_DAC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>AUDIO_CODEC_DAC_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                                          |
| 26:24          | R/W        | 0x0         | CLK_SRC_SE<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO1(DIV2)<br>10: PLL_AUDIO1(DIV5)                    |
| 23:10          | /          | /           | /                                                                                                                          |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                               |
| 7:5            | /          | /           | /                                                                                                                          |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                        |

### 3.3.6.83 0x0A54 AUDIO\_CODEC\_ADC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0A54 |            |             | Register Name: AUDIO_CODEC_ADC_CLK_REG                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31             | R/W        | 0x0         | AUDIO_CODEC_ADC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>AUDIO_CODEC_ADC_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                                          |
| 26:24          | R/W        | 0x0         | CLK_SRC_SE<br>Clock Source Select<br>00: PLL_AUDIO0(1X)<br>01: PLL_AUDIO1(DIV2)<br>10: PLL_AUDIO1(DIV5)                    |
| 23:10          | /          | /           | /                                                                                                                          |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: /1<br>01: /2<br>10: /4<br>11: /8                                                               |
| 7:5            | /          | /           | /                                                                                                                          |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                        |

### 3.3.6.84 0x0A5C AUDIO\_CODEC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0A5C |            |             | Register Name: AUDIO_CODEC_BGR_REG                                |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31:17          | /          | /           | /                                                                 |
| 16             | R/W        | 0x0         | AUDIO_CODEC_RST<br>AUDIO_CODEC Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x0A5C |            |             | Register Name: AUDIO_CODEC_BGR_REG                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 15:1           | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | AUDIO_CODEC_GATING<br>Gating Clock For AUDIO_CODEC<br>0: Mask<br>1: Pass |

### 3.3.6.85 0x0A70 USBO Clock Register (Default Value: 0x0000\_0000)

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

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

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

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

| Offset: 0x0A8C |            |             | Register Name: USB_BGR_REG                                  |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:25          | /          | /           | /                                                           |
| 24             | R/W        | 0x0         | USBOTG0_RST<br>USBOTG0 Reset<br>0: Assert<br>1: De-assert   |
| 23:22          | /          | /           | /                                                           |
| 21             | R/W        | 0x0         | USBEHCI1_RST<br>USBEHCI1 Reset<br>0: Assert<br>1: De-assert |

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

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

| Offset: 0x0ABC |            |             | Register Name: DPSS_TOP_BGR_REG                                    |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:17          | /          | /           | /                                                                  |
| 16             | R/W        | 0x0         | DPSS_TOP_RST<br>DPSS_TOP Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x0         | DPSS_TOP_GATING<br>Gating Clock For DPSS_TOP<br>0: Mask<br>1: Pass |

### 3.3.6.89 0x0B24 DSI Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B24 |            |             | Register Name: DSI_CLK_REG                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31             | R/W        | 0x0         | DSI_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DSI_CLK = Clock Source/M.                                            |
| 30:27          | /          | /           | /                                                                                                                                           |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_PERI(1X)<br>010: PLL_VIDEO0(2X)<br>011: PLL_VIDEO1(2X)<br>100: PLL_AUDIO1(DIV2) |
| 23:4           | /          | /           | /                                                                                                                                           |

| Offset: 0x0B24 |            |             | Register Name: DSI_CLK_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15. |

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

| Offset: 0x0B4C |            |             | Register Name: DSI_BGR_REG                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:17          | /          | /           | /                                                        |
| 16             | R/W        | 0x0         | DSI_RST<br>DSI Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                        |
| 0              | R/W        | 0x0         | DSI_GATING<br>Gating Clock For DSI<br>0: Mask<br>1: Pass |

### 3.3.6.91 0x0B60 TCONLCD Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B60 |            |             | Register Name: TCONLCD_CLK_REG                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31             | R/W        | 0x0         | TCONLCD_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TCONLCD_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                          |

| Offset: 0x0B60 |            |             | Register Name: TCONLCD_CLK_REG                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 26:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>000: PLL_VIDEO0(1X)<br/>001: PLL_VIDEO0(4X)<br/>010: PLL_VIDEO1(1X)<br/>011: PLL_VIDEO1(4X)<br/>100: PLL_PERI(2X)<br/>101: PLL_AUDIO1(DIV2)</p> |
| 23:10          | /          | /           | /                                                                                                                                                                                          |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N<br/>Factor N<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: 8</p>                                                                                                                       |
| 7:4            | /          | /           | /                                                                                                                                                                                          |
| 3:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/>M= FACTOR_M +1.<br/>FACTOR_M is from 0 to 15.</p>                                                                                                             |

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

| Offset: 0x0B7C |            |             | Register Name: TCONLCD_BGR_REG                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:17          | /          | /           | /                                                                           |
| 16             | R/W        | 0x0         | <p>TCONLCD_RST<br/>TCON LCD Reset<br/>0: Assert<br/>1: DE-assert</p>        |
| 15:1           | /          | /           | /                                                                           |
| 0              | R/W        | 0x0         | <p>TCONLCD_GATING<br/>Gating Clock For TCON LCD<br/>0: Mask<br/>1: Pass</p> |

### 3.3.6.93 0x0B80 TCONTV Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0B80 |            |             | Register Name: TCONTV_CLK_REG                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31             | R/W        | 0x0         | TCONTV_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TCONTV_CLK = Clock Source/M/N.                                                                     |
| 30:27          | /          | /           | /                                                                                                                                                                            |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_VIDEO0(1X)<br>001: PLL_VIDEO0(4X)<br>010: PLL_VIDEO1(1X)<br>011: PLL_VIDEO1(4X)<br>100: PLL_PERI(2X)<br>101: PLL_AUDIO1(DIV2) |
| 23:10          | /          | /           | /                                                                                                                                                                            |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                                                                                                                     |
| 7:4            | /          | /           | /                                                                                                                                                                            |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                                                                                          |

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

| Offset: 0x0B9C |            |             | Register Name: TCONTV_BGR_REG                                   |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:17          | /          | /           | /                                                               |
| 16             | R/W        | 0x0         | TCONTV_RST<br>TCONTV Reset<br>0: Assert<br>1: DE-assert         |
| 15:1           | /          | /           | /                                                               |
| 0              | R/W        | 0x0         | TCONTV_GATING.<br>Gating Clock For TCONTV<br>0: Mask<br>1: Pass |

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

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

### 3.3.6.96 0x0BB0 TVE Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0BB0 |            |             | Register Name: TVE_CLK_REG                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31             | R/W        | 0x0         | TVE_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TVE_CLK = Clock Source/M/N. |
| 30:27          | /          | /           | /                                                                                                  |

| Offset: 0x0BB0 |            |             | Register Name: TVE_CLK_REG                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 26:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>000: PLL_VIDEO0(1X)<br/>001: PLL_VIDEO0(4X)<br/>010: PLL_VIDEO1(1X)<br/>011: PLL_VIDEO1(4X)<br/>100: PLL_PERI(2X)<br/>101: PLL_AUDIO1(DIV2)</p> |
| 23:10          | /          | /           | /                                                                                                                                                                                          |
| 9:8            | R/W        | 0x0         | <p>FACTOR_N<br/>Factor N<br/>00: 1<br/>01: 2<br/>10: 4<br/>11: 8</p>                                                                                                                       |
| 7:4            | /          | /           | /                                                                                                                                                                                          |
| 3:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/>M= FACTOR_M +1<br/>FACTOR_M is from 0 to 15.</p>                                                                                                              |

### 3.3.6.97 0x0BBC TVE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0BBC |            |             | Register Name: TVE_BGR_REG                                          |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:18          | /          | /           | /                                                                   |
| 17             | R/W        | 0x0         | <p>TVE_RST<br/>TVE Reset<br/>0: Assert<br/>1: DE-assert</p>         |
| 16             | R/W        | 0x0         | <p>TVE_TOP_RST<br/>TVE_TOP Reset<br/>0: Assert<br/>1: DE-assert</p> |
| 15:2           | /          | /           | /                                                                   |

| Offset: 0x0BBC |            |             | Register Name: TVE_BGR_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 1              | R/W        | 0x0         | TVE_GATING<br>Gating Clock For TVE<br>0: Mask<br>1: Pass         |
| 0              | R/W        | 0x0         | TVE_TOP_GATING<br>Gating Clock For TVE_TOP<br>0: Mask<br>1: Pass |

### 3.3.6.98 0x0BC0 TVD Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0BC0 |            |             | Register Name: TVD_CLK_REG                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31             | R/W        | 0x0         | TVD_CLK_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TVD_CLK = Clock Source/M.           |
| 30:27          | /          | /           | /                                                                                                                  |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_VIDEO0(1X)<br>010: PLL_VIDEO1(1X)<br>011: PLL_PERI(1X) |
| 23:5           | /          | /           | /                                                                                                                  |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                |

### 3.3.6.99 0x0BDC TVD Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0BDC |            |             | Register Name: TVD_BGR_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:18          | /          | /           | /                                                                |
| 17             | R/W        | 0x0         | TVD_RST<br>TVD Reset<br>0: Assert<br>1: De-assert                |
| 16             | R/W        | 0x0         | TVD_TOP_RST<br>TVD_TOP Reset<br>0: Assert<br>1: De-assert        |
| 15:2           | /          | /           | /                                                                |
| 1              | R/W        | 0x0         | TVD_GATING<br>Gating Clock For TVD<br>0: Mask<br>1: Pass         |
| 0              | R/W        | 0x0         | TVD_TOP_GATING<br>Gating Clock For TVD_TOP<br>0: Mask<br>1: Pass |

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

| Offset: 0x0BF0 |            |             | Register Name: LEDC_CLK_REG                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31             | R/W        | 0x0         | LDEC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>LEDC_CLK = Clock Source/M/N. |
| 30:25          | /          | /           | /                                                                                                    |
| 24             | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>0: HOSC<br>1: PLL_PERI(1X)                                     |

| Offset: 0x0BFO |            |             | Register Name: LEDC_CLK_REG                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 23:10          | /          | /           | /                                                                        |
| 9:8            | R/W        | 0x0         | FACTOR_N<br>Factor N<br>00: 1<br>01: 2<br>10: 4<br>11: 8                 |
| 7:4            | /          | /           | /                                                                        |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>$M = FACTOR\_M + 1$<br>FACTOR_M is from 0 to 15. |

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

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

**3.3.6.102 0x0C04 CSI Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0C04 |            |             | Register Name: CSI_CLK_REG                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31             | R/W        | 0x0         | CSI_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_CLK = Clock Source/M.      |
| 30:27          | /          | /           | /                                                                                                     |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: PLL_PERI(2X)<br>001: PLL_VIDEO0(2X)<br>010: PLL_VIDEO1(2X) |
| 23:4           | /          | /           | /                                                                                                     |
| 3:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 15.                                   |

**3.3.6.103 0x0C08 CSI Master Clock Register (Default Value: 0x0000\_0000)**

| Offset: 0x0C08 |            |             | Register Name: CSI_MASTER_CLK_REG                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31             | R/W        | 0x0         | CSI_MASTER_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>CSI_MASTER_CLK = Clock Source/M. |
| 30:27          | /          | /           | /                                                                                                              |

| Offset: 0x0C08 |            |             | Register Name: CSI_MASTER_CLK_REG                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 26:24          | R/W        | 0x0         | <p>CLK_SRC_SEL<br/>Clock Source Select<br/>000: HOSC<br/>001: PLL_PERI(1X)<br/>010: PLL_VIDEO0(1X)<br/>011: PLL_VIDEO1(1X)<br/>100: PLL_AUDIO1(DIV2)<br/>101: PLL_AUDIO1(DIV5)</p> |
| 23:5           | /          | /           | /                                                                                                                                                                                  |
| 4:0            | R/W        | 0x0         | <p>FACTOR_M<br/>Factor M<br/><math>M = \text{FACTOR\_M} + 1</math><br/>FACTOR_M is from 0 to 31.</p>                                                                               |

### 3.3.6.104 0x0C1C CSI Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0C1C |            |             | Register Name: CSI_BGR_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:17          | /          | /           | /                                                                  |
| 16             | R/W        | 0x0         | <p>CSI_RST<br/>CSI Reset<br/>0: Assert<br/>1: DE-assert</p>        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x0         | <p>CSI_GATING<br/>Gating Clock For CSI<br/>0: Mask<br/>1: Pass</p> |

### 3.3.6.105 0x0C50 TPADC Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C50 |            |             | Register Name: TPADC_CLK_REG                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31             | R/W        | 0x0         | TPADC_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>TPADC_CLK = Clock Source. |
| 30:27          | /          | /           | /                                                                                                  |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: PLL_AUDIO0(1X)                             |
| 23:0           | /          | /           | /                                                                                                  |

### 3.3.6.106 0x0C5C TPADC Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0C5C |            |             | Register Name: TPADC_BGR_REG                                 |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:17          | /          | /           | /                                                            |
| 16             | R/W        | 0x0         | TPADC_RST<br>TPADC Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                            |
| 0              | R/W        | 0x0         | TPADC_GATING<br>Gating Clock For TPADC<br>0: Mask<br>1: Pass |

### 3.3.6.107 0x0C70 DSP Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0C70 |            |             | Register Name: DSP_CLK_REG                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31             | R/W        | 0x0         | DSP_CLK_GATING<br>Gating Clock<br>0: Clock is OFF<br>1: Clock is ON<br>DSP_CLK = Clock Source/M.                               |
| 30:27          | /          | /           | /                                                                                                                              |
| 26:24          | R/W        | 0x0         | CLK_SRC_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK32K<br>010: CLK16M_RC<br>011: PLL_PERI(2X)<br>100: PLL_AUDIO1(DIV2) |
| 23:5           | /          | /           | /                                                                                                                              |
| 4:0            | R/W        | 0x0         | FACTOR_M<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                                                            |

### 3.3.6.108 0x0C7C DSP Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0C7C |            |             | Register Name: DSP_BGR_REG                                |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:19          | /          | /           | /                                                         |
| 18             | R/W        | 0x0         | DSP_DBG_RST<br>DSP_DBG Reset<br>0: Assert<br>1: De-assert |
| 17             | R/W        | 0x0         | DSP_CFG_RST<br>DSP_CFG Reset<br>0: Assert<br>1: De-assert |

| Offset: 0x0C7C |            |             | Register Name: DSP_BGR_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 16             | R/W        | 0x0         | DSP_RST<br>DSP Reset<br>0: Assert<br>1: De-assert                |
| 15:2           | /          | /           | /                                                                |
| 1              | R/W        | 0x0         | DSP_CFG_GATING<br>Gating Clock For DSP_CFG<br>0: Mask<br>1: Pass |
| 0              | /          | /           | /                                                                |

### 3.3.6.109 0x0D00 RISC-V Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0D00 |            |             | Register Name: RISC-V_CLK_REG                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                      |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                |
| 26:24          | R/W        | 0x0         | RISC-V_CLK_SEL<br>Clock Source Select<br>000: HOSC<br>001: CLK32K<br>010: CLK16M_RC<br>011: PLL_PERI(800M)<br>100: PLL_PERI(1X)<br>101: PLL_CPU<br>110: PLL_AUDIO1(DIV2)<br>RISC-V Clock = Clock Source/M.<br>RISC-V_AXI Clock = RISC-V Clock/N. |
| 23:10          | /          | /           | /                                                                                                                                                                                                                                                |
| 9:8            | R/W        | 0x1         | RISC-V_AXI_DIV_CFG<br>Factor N<br>N = FACTOR_N +1<br>FACTOR_N is from 1 to 3.<br><b>Note: The clock division is lack of glitch switching and supports dynamic configuration.</b>                                                                 |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                |

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

### 3.3.6.110 0x0D04 RISC-V GATING Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0D04 |            |             | Register Name: RISC-V_GATING_REG                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31             | R/W        | 0x1         | RISC-V_GATING<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON               |
| 30:16          | /          | /           | /                                                                                        |
| 15:0           | W          | 0x0         | RISC-V_GATING_FIELD<br>If RISC-V_gating_field == 16'h16AA, the bit 31 can be configured. |

### 3.3.6.111 0x0D0C RISC-V\_CFG Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0D0C |            |             | Register Name: RISC-V_CFG_BGR_REG                                  |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:17          | /          | /           | /                                                                  |
| 16             | R/W        | 0x0         | RISC-V_CFG_RST<br>RISC-V Reset<br>0: Assert<br>1: De-assert        |
| 15:1           | /          | /           | /                                                                  |
| 0              | R/W        | 0x0         | RISC-V_CFG_GATING<br>Gating Clock For RISC-V<br>0: Mask<br>1: Pass |

### 3.3.6.112 0x0F04 PLL Lock Debug Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0F04 |            |             | Register Name: PLL_LOCK_DBG_CTRL_REG                        |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31             | R/W        | 0x0         | PLL_LOCK_FLAG_EN<br>Debug Enable<br>0: Disable<br>1: Enable |
| 30:23          | /          | /           | /                                                           |

| Offset: 0x0F04 |            |             | Register Name: PLL_LOCK_DBG_CTRL_REG                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 22:20          | R/W        | 0x0         | PLL_LOCK_FLAG_SEL<br>Debug Select<br>000: PLL_CPUX<br>001: PLL_DDR<br>010: PLL_PERI(2X)<br>011: PLL_VIDEO0(4X)<br>100: PLL_VIDEO1(4X)<br>101: PLL_VE<br>110: PLL_AUDIO0<br>111: PLL_AUDIO1<br>Others: / |
| 19:0           | /          | /           | /                                                                                                                                                                                                       |

### 3.3.6.113 0x0F08 Frequence Detect Control Register (Default Value: 0x0000\_0020)

| Offset: 0x0F08 |            |             | Register Name: FRE_DET_CTRL_REG                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31             | R/WOC      | 0x0         | ERROR_FLAG<br>Error Flag<br>0: Write 0 to clear<br>1: Error                     |
| 30:9           | /          | /           | /                                                                               |
| 8:4            | R/W        | 0x2         | DET_TIME<br>Detect Time<br>Time=1/32k*(2^RegValue)<br>RegValue is from 0 to 16. |
| 3:2            | /          | /           | /                                                                               |
| 1              | R/W        | 0x0         | FRE_DET_IRQ_EN<br>Frequence Detect IRQ Enable<br>0: Disable<br>1: Enable        |
| 0              | R/W        | 0x0         | FRE_DET_FUN_EN<br>Frequence Detect Function Enable<br>0: Disable<br>1: Enable   |

**3.3.6.114 0x0FOC Frequence Up Limit Register (Default Value: 0x0000\_0000)**

| Offset: 0x0FOC |            |             | Register Name: FRE_UP_LIM_REG                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31:0           | R/W        | 0x0         | FRE_UP_LIM<br>Frequence Up Limit<br><b>The value of the register must be an integral multiple of 32. The unit is kHz.</b> |

**3.3.6.115 0x0F10 Frequence Down Limit Register (Default Value: 0x0000\_0000)**

| Offset: 0x0F10 |            |             | Register Name: FRE_DOWN_LIM_REG                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31:0           | R/W        | 0x0         | FRE_DOWN_LIM<br>Frequence Down Limit<br><b>The value of the register must be an integral multiple of 32. The unit is kHz.</b> |

**3.3.6.116 0x0F30 CCU FANOUT Clock Gate Register (Default Value: 0x0000\_0000)**

| Offset: 0x0F30 |            |             | Register Name: CCU_FAN_GATE_REG                                     |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:5           | /          | /           | /                                                                   |
| 4              | R/W        | 0x0         | CLK32K_EN<br>Gating for CLK32K<br>0: Clock is OFF<br>1: Clock is ON |
| 3              | R/W        | 0x0         | CLK25M_EN<br>Gating for CLK25M<br>0: Clock is OFF<br>1: Clock is ON |

| Offset: 0x0F30 |            |             | Register Name: CCU_FAN_GATE_REG                                     |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 2              | R/W        | 0x0         | CLK16M_EN<br>Gating for CLK16M<br>0: Clock is OFF<br>1: Clock is ON |
| 1              | R/W        | 0x0         | CLK12M_EN<br>Gating for CLK12M<br>0: Clock is OFF<br>1: Clock is ON |
| 0              | R/W        | 0x0         | CLK24M_EN<br>Gating for CLK24M<br>0: Clock is OFF<br>1: Clock is ON |

### 3.3.6.117 0x0F34 CLK27M FANOUT Register (Default Value: 0x0000\_0000)

| Offset: 0x0F34 |            |             | Register Name: CLK27M_FAN_REG                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31             | R/W        | 0x0         | CLK27M_EN<br>Gating for CLK27M<br>0: Clock is OFF<br>1: Clock is ON<br>SCLK = Clock Source/M/N.         |
| 30:26          | /          | /           | /                                                                                                       |
| 25:24          | R/W        | 0x0         | CLK27M_SCR_SEL<br>Clock Source Select<br>000: PLL_VIDEO0(1X)<br>001: PLL_VIDEO1(1X)<br>010: /<br>011: / |
| 23:10          | /          | /           | /                                                                                                       |
| 9:8            | R/W        | 0x0         | CLK27M_DIV1<br>Factor N<br>N= FACTOR_N +1.<br>FACTOR_N is from 0 to 3.                                  |
| 7:5            | /          | /           | /                                                                                                       |

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

### 3.3.6.118 0x0F38 PCLK FANOUT Register (Default Value: 0x0000\_0000)

| Offset: 0x0F38 |            |             | Register Name: PCLK_FAN_REG                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31             | R/W        | 0x0         | PCLK_DIV_EN<br>Gating for PCLK<br>0: Clock is OFF<br>1: Clock is ON<br>PCLK = APB0_CLK/M. |
| 30:5           | /          | /           | /                                                                                         |
| 4:0            | R/W        | 0x0         | PCLK_DIV<br>Factor M<br>M= FACTOR_M +1<br>FACTOR_M is from 0 to 31.                       |

### 3.3.6.119 0x0F3C CCU FANOUT Register (Default Value: 0x0000\_0000)

| Offset: 0x0F3C |            |             | Register Name: CCU_FAN_REG                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:27          | /          | /           | /                                                                             |
| 26:24          | R/W        | 0x0         | Reserved                                                                      |
| 23             | R/W        | 0x0         | CLK_FANOUT2_EN<br>Gating for CLK_FANOUT2<br>0: Clock is OFF<br>1: Clock is ON |
| 22             | R/W        | 0x0         | CLK_FANOUT1_EN<br>Gating for CLK_FANOUT1<br>0: Clock is OFF<br>1: Clock is ON |

| Offset: 0x0F3C |            |             | Register Name: CCU_FAN_REG                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                  |
| 21             | R/W        | 0x0         | CLK_FANOUT0_EN<br>Gating for CLK_FANOUT0<br>0: Clock is OFF<br>1: Clock is ON                                                                                                                                                                                                |
| 20:18          | /          | /           | /                                                                                                                                                                                                                                                                            |
| 17:9           | R/W        | 0x0         | Reserved                                                                                                                                                                                                                                                                     |
| 8:6            | R/W        | 0x0         | CLK_FANOUT2_SEL<br>000:CLK32K (From PLL_PERI(2X))<br>001:CLK12M (From DCXO/2)<br>010:CLK16M (From PLL_PERI(2X))<br>011:CLK24M (From DCXO)<br>100:CLK25M (From PLL_PERI(1X))<br>101:CLK27M<br>110:PCLK<br>CLK_FANOUT2 can be selected to output from the above seven sources. |
| 5:3            | R/W        | 0x0         | CLK_FANOUT1_SEL<br>000:CLK32K (From PLL_PERI(2X))<br>001:CLK12M (From DCXO/2)<br>010:CLK16M (From PLL_PERI(2X))<br>011:CLK24M (From DCXO)<br>100:CLK25M (From PLL_PERI(1X))<br>101:CLK27M<br>110:PCLK<br>CLK_FANOUT1 can be selected to output from the above seven sources. |
| 2:0            | R/W        | 0x0         | CLK_FANOUT0_SEL<br>000:CLK32K (From PLL_PERI(2X))<br>001:CLK12M (From DCXO)<br>010:CLK16M (From PLL_PERI(2X))<br>011:CLK24M (From DCXO)<br>100:CLK25M (From PLL_PERI(1X))<br>101:CLK27M<br>110:PCLK<br>CLK_FANOUT0 can be selected to output from the above seven sources.   |

## 3.4 BROM System

### 3.4.1 Overview

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

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

The BROM system includes the following features:

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

### 3.4.2 Functional Description

#### 3.4.2.1 Selecting the Boot Medium

The BROM system supports the following boot media:

- SD card
- eMMC
- SPI NOR FLASH
- SPI NAND FLASH

There are two ways to select the boot medium: GPIO Pin Select and eFuse Select. On startup, the BROM will read the state of BOOT\_MODE, and decide whether the GPIO or eFuse to select the type of boot medium based on the state of BOOT\_MODE. The BOOT\_MODE is the bit of the SID module (register: 0x03006210).

The following table shows BOOT\_MODE Setting.

**Table 3-6 BOOT\_MODE Setting**

| BOOT_MODE | Boot_Select Type                                                                             |
|-----------|----------------------------------------------------------------------------------------------|
| 0         | GPIO boot select, indicates that the boot medium is decided by the value of the GPIO pin.    |
| 1         | eFuse boot select, indicates that the boot medium is decided by the value of the eFuse type. |

### GPIO Boot Select

If the state of the BOOT\_MODE is 0, the boot medium is decided by the value of the GPIO pin. The following table shows the boot medium priority. The boot medium priority describes the possibility that each medium to be selected as the boot medium. The BROM reads the boot0 of the medium with the highest priority first. If the medium does not exist or has any problems, the BROM will try the next medium. Otherwise, the medium will be selected as the boot medium.

**Table 3-7 GPIO Boot Select Configuration**

| Pin_Boot_Select[1:0] | Boot Medium Priority                      |
|----------------------|-------------------------------------------|
| 00                   | SPI NOR->SPI NAND                         |
| 01                   | SMHCO->SPI NOR->other media               |
| 10                   | SMHCO->SPI NAND->other media              |
| 11                   | SMHCO->EMMC2_BOOT->EMMC2_USR->other media |



The status of the GPIO boot select pin can be read by the bit[12:11] of the system configuration module (register: 0x03000024).

### eFuse Boot Select

If the state of the BOOT\_MODE is 1, the boot medium is decided by the value of eFuse\_Boot\_Select\_Cfg. The eFuse\_Boot\_Select\_Cfg is divided into 4 groups and each group is 3-bit. The following table shows the groups of eFUSE\_Boot\_Select.

 **NOTE**

The status of the efuse boot select pin can be read by the bit[27:16] of the SID module (register: 0x03006210).

**Table 3-8 Groups of eFuse\_Boot\_Select**

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

The four groups take effect with the following priority:

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

For example, eFuse\_Boot\_Select\_2 will not take effect unless eFuse\_Boot\_Select\_1 is set as 0x111, eFuse\_Boot\_Select\_3 will not take effect unless eFuse\_Boot\_Select\_2 is set as 0x111, and so on.

The following table shows the boot medium priority for the different values of eFuse\_Boot\_Select\_n, where n = [4:1]. The eFuse\_Boot\_Select\_1 to eFuse\_Boot\_Select\_3 are the same setting. But for eFuse\_Boot\_Select\_4, if its value is 0x111, the BROM will select the boot medium in the Try mode. The BROM in the Try mode follows the order below to select the boot medium:

**SMHC0 -> SPI NOR -> SPI NAND -> SMHC2**

**Table 3-9 eFuse Boot Select Setting**

| eFuse_Boot_Select_n | Boot Medium Priority                |
|---------------------|-------------------------------------|
| 000                 | Select the boot medium in Try mode. |
| 001                 | Reserved                            |
| 010                 | SHMC2                               |
| 011                 | SPI NOR                             |
| 100                 | SPI NAND                            |
| 101                 | Reserved                            |
| 110                 | Reserved                            |

| eFuse_Boot_Select_n | Boot Medium Priority                                                                                                                                                  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 111                 | <p>When n is 1 to 3:<br/>The boot medium is decided by the value of <b>eFuse_Boot_Select_(n + 1)</b>.</p> <p>When n is 4:<br/>Select the boot medium in Try mode.</p> |

### 3.4.2.2 Selecting the Boot Mode

For SoCs that have implemented and enabled the ARM TrustZone technology, there are two boot modes: Normal BROM Mode and Secure BROM Mode. Secure BROM Mode is designed to protect against the potential threat that attackers modify the code or data areas in programmable memory.

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



The ARM TrustZone feature is the minimal security functionality an ARM-TrustZone-technology-based system must implement for its Trusted Boot. You can enable the ARM TrustZone feature by configuring the Secure Enable Bit as enabled.

#### Normal BROM Mode

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

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

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

### Secure BROM Mode

The Secure BROM Mode has the following features:

- Supports X509 certificate
  - The certificate is used to check whether the Security Boot software is modified or replaced. Before running the Security Boot software, the system checks the integrity of the certificate make sure the software has not been modified or replaced.
- Supports cryptographic algorithms
  - SHA-256
  - RSA-2048

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

- Supports OTP/eFuse

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

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

**Figure 3-7 Boot Process in Secure BROM Mode**



### 3.4.2.3 NON\_CPU0 Boot Process

If CPU ID is greater than 0, the system boot from NON\_CPU0, the BROM will read the Soft Entry Address Register, then jump the Soft Entry Address, and run NON\_CPU0 boot code. The following figure shows the NON\_CPU0 Boot Process.

Figure 3-8 NON\_CPU0 Boot Process Diagram



#### NOTE

The Soft Entry Address Register of CPU0 is 0x070005C4.

The Soft Entry Address Register of CPU1 is 0x070005C8.

### 3.4.2.4 CPU0 Hotplug Process

The Hotplug Flag determines whether the system will do Hotplug boot, if the CPU Hotplug Flag value is equal to 0xFA50392F, then read the Soft Entry Register and the system will jump to the Soft Entry Address. The following figure shows the CPU0 Hotplug Process.

Figure 3-9 CPU0 Hotplug Process Diagram



- The Hotplug Flag Register is 0x070005C0.
- The Soft Entry Address Register is 0x070005C4.

### 3.4.2.5 Mandatory Upgrade Process

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

Figure 3-10 Mandatory Upgrade Process



- The FEL address of the Normal BROM is 0x20.
- The FEL address of the Secure BROM is 0x64.
- The status of the FEL pin is the bit[8] of the system configuration module (register: 0x03000024).

#### 3.4.2.6 FEL Process

When the system chooses to enter the Mandatory Upgrade Process, the system will jump to the FEL process.

The following figure shows the FEL upgrade process.

Figure 3-11 USB FEL Process



### 3.4.2.7 Fast Boot Process

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

Table 3-10 Fast Boot Select Setting

| Reg_bit[31:28] | Boot Medium Priority                       |
|----------------|--------------------------------------------|
| 1              | Try process                                |
| 2              | SMHC0->EMMC2_USER->EMMC2_BOOT->Other media |
| 3              | SMHC0->SPI NOR->Other media                |
| 4              | SMHC0->SPI NAND->Other media               |
| 5              | EMMC2_BOOT->EMMC2_USER->Other media        |
| 6              | SMHC0->Try process                         |
| 7              | SMHC0->Try process                         |

**NOTE**

- The bit[28:0] of Fast Boot register is used to record the media information.
- The try process is SMHC0->SPI NOR->SPI NAND->EMMC2\_USER->EMMC2\_BOOT.

## 3.5 System Configuration

### 3.5.1 Overview

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

### 3.5.2 Register List

| Module Name | Base Address |
|-------------|--------------|
| SYS_CFG     | 0x03000000   |

| Register Name       | Offset | Description                              |
|---------------------|--------|------------------------------------------|
| DSP_BOOT_RAMMAP_REG | 0x0008 | DSP Boot SRAM Remap Control Register     |
| VER_REG             | 0x0024 | Version Register                         |
| EMAC_EPHY_CLK_REG0  | 0x0030 | EMAC-EPHY Clock Register 0               |
| SYS_LDO_CTRL_REG    | 0x0150 | System LDO Control Register              |
| RESCAL_CTRL_REG     | 0x0160 | Resistor Calibration Control Register    |
| RES240_CTRL_REG     | 0x0168 | 240ohms Resistor Manual Control Register |
| RESCAL_STATUS_REG   | 0x016C | Resistor Calibration Status Register     |

### 3.5.3 Register Description

#### 3.5.3.1 0x0008 DSP Boot SRAM Remap Register (Default Value: 0x0000\_0001)

| Offset: 0x0008 |            |             | Register Name: DSP_BOOT_RAMMAP_REG                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:1           | /          | /           | /                                                                                                                                                                                            |
| 0              | R/W        | 0x1         | DSP BOOT SRAM REMAP ENABLE<br>0: DSP 128K Local SRAM Remap for DSP_SYS<br>1: DSP 128K Local SRAM Remap for System Boot<br>After system boots up, this bit must be set to 0 before using DSP. |

### 3.5.3.2 0x0024 Version Register (Default Value: UDF)

| Offset: 0x0024 |            |             | Register Name: VER_REG                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:13          | /          | /           | /                                                                                                                           |
| 12:11          | R          | UDF         | BOOT_SEL_PAD_STA<br>The value of this bit decides the priority order for each medium type to be selected as the boot media. |
| 10:9           | /          | /           | /                                                                                                                           |
| 8              | R          | UDF         | FEL_SEL_PAD_STA<br>Fel_Select_Pin_Status<br>0: Run_FEL<br>1: Try_Media_Boot                                                 |
| 7:0            | /          | /           | /                                                                                                                           |

### 3.5.3.3 0x0030 EMAC-EPHY Clock Register 0 (Default Value: 0x0005\_8000)

| Offset: 0x0030 |            |             | Register Name: EMAC_EPHY_CLK_REG0                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:28          | R/W        | 0x0         | BPS_EFUSE                                                                                                            |
| 27             | R/W        | 0x0         | XMII_SEL<br>0: Internal SMI and MII<br>1: External SMI and MII                                                       |
| 26:25          | R/W        | 0x0         | EPHY_MODE<br>Operation Mode Selection<br>00: Normal Mode<br>01: Simulation Mode<br>10: AFE Test Mode<br>11: Reserved |
| 24:20          | R/W        | 0x0         | PHY_ADDR<br>PHY Address                                                                                              |
| 19             | R/W        | 0x0         | Reserved                                                                                                             |
| 18             | R/W        | 0x1         | CLK_SEL<br>0: 25 MHz<br>1: 24 MHz                                                                                    |

| Offset: 0x0030 |            |             | Register Name: EMAC_EPHY_CLK_REG0                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 17             | R/W        | 0x0         | LED_POL<br>0: High active<br>1: Low active                                                                                                                                |
| 16             | R/W        | 0x1         | SHUTDOWN<br>0: Power up<br>1: Shut down                                                                                                                                   |
| 15             | R/W        | 0x1         | PHY_SELECT<br>0: External PHY<br>1: Internal PHY                                                                                                                          |
| 14             | /          | /           | /                                                                                                                                                                         |
| 13             | R/W        | 0x0         | RMII_EN<br>0: Disable RMII Module<br>1: Enable RMII Module<br>This bit is prior to bit[2]. When this bit is asserted, the MII and RGMII interfaces will be both disabled. |
| 12:10          | R/W        | 0x0         | ETXDC<br>Configure EMAC Transmit Clock Delay Chain                                                                                                                        |
| 9:5            | R/W        | 0x0         | ERXDC<br>Configure EMAC Receive Clock Delay Chain                                                                                                                         |
| 4              | R/W        | 0x0         | ERXIE<br>Enable EMAC Receive Clock Invertor<br>0: Disabled<br>1: Enabled                                                                                                  |
| 3              | R/W        | 0x0         | ETXIE<br>Enable EMAC Transmit Clock Invertor<br>0: Disabled<br>1: Enabled                                                                                                 |
| 2              | R/W        | 0x0         | EPIT<br>EMAC PHY Interface Type<br>0: MII<br>1: RGMII                                                                                                                     |

| Offset: 0x0030 |            |             | Register Name: EMAC_EPHY_CLK_REG0                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                           |
| 1:0            | R/W        | 0x0         | <p>ETCS<br/>EMAC Transmit Clock Source<br/>00: Transmit clock source for MII<br/>01: External transmit clock source for GMII and RGMII<br/>10: Internal transmit clock source for GMII and RGMII<br/>11: Reserved</p> |

### 3.5.3.4 0x0150 System LDO Control Register (Default Value: 0x0000\_0EOF)

| Offset: 0x0150 |            |             | Register Name: SYS_LDO_CTRL_REG                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                         |
| 31:24          | R/W        | 0x0         | <p>SPARE<br/>Reserved spare register</p>                                                                                                                                                                                                                                                                            |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 21             | R/W        | 0x0         | reserved                                                                                                                                                                                                                                                                                                            |
| 20             | R/W        | 0x0         | reserved                                                                                                                                                                                                                                                                                                            |
| 19:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 17             | R/W        | 0x0         | reserved                                                                                                                                                                                                                                                                                                            |
| 16             | R/W        | 0x0         | reserved                                                                                                                                                                                                                                                                                                            |
| 15:8           | R/W        | 0xE         | <p>LDOB_TRIM<br/>LDOB Trimming.<br/>Adjust LDOB output, only the low 6-bit is used.</p> <p>000000:1.167<br/>000001:1.18<br/>000010:1.193<br/>000011:1.207<br/>000100:1.22<br/>000101:1.233<br/>000110:1.247<br/>000111:1.260<br/>001000:1.273<br/>001001:1.287<br/>001010:1.3<br/>001011:1.313<br/>001100:1.327</p> |

| Offset: 0x0150 |            |             | Register Name: SYS_LDO_CTRL_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
|                |            |             | 001101:1.340                    |
|                |            |             | 001110:1.353 (default)          |
|                |            |             | 001111:1.367                    |
|                |            |             | 010000:1.38                     |
|                |            |             | 010001:1.393                    |
|                |            |             | 010010:1.407                    |
|                |            |             | 010011:1.42                     |
|                |            |             | 010100:1.433                    |
|                |            |             | 010101:1.447                    |
|                |            |             | 010110:1.46                     |
|                |            |             | 010111:1.473                    |
|                |            |             | 011000:1.487                    |
|                |            |             | 011001:1.5                      |
|                |            |             | 011010:1.513                    |
|                |            |             | 011011:1.527                    |
|                |            |             | 011100:1.54                     |
|                |            |             | 011101:1.553                    |
|                |            |             | 011110:1.567                    |
|                |            |             | 011111:1.58                     |
|                |            |             | 100000:1.593                    |
|                |            |             | 100001:1.607                    |
|                |            |             | 100010:1.627                    |
|                |            |             | 100011:1.64                     |
|                |            |             | 100100:1.653                    |
|                |            |             | 100101:1.667                    |
|                |            |             | 100110:1.680                    |
|                |            |             | 100111:1.693                    |
|                |            |             | 101000:1.707                    |
|                |            |             | 101001:1.720                    |
|                |            |             | 101010:1.733                    |
|                |            |             | 101011:1.747                    |
|                |            |             | 101100:1.76                     |
|                |            |             | 101101:1.773                    |
|                |            |             | 101110:1.787                    |
|                |            |             | 101111:1.8                      |
|                |            |             | 110000:1.813                    |
|                |            |             | 110001:1.827                    |

| Offset: 0x0150 |            |             | Register Name: SYS_LDO_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:0            | R/W        | 0xF         | <p>LDOA_TIM.<br/>LDOA Trimming<br/>Adjust LDOA output, only the low 5-bit is used.</p> <p>00000:1.593<br/>00001:1.607<br/>00010:1.627<br/>00011:1.64<br/>00100:1.653<br/>00101:1.667<br/>00110:1.680<br/>00111:1.693<br/>01000:1.707<br/>01001:1.720<br/>01010:1.733<br/>01011:1.747<br/>01100:1.76<br/>01101:1.773<br/>01110:1.787<br/>01111:1.8 (default)<br/>10000:1.813<br/>10001:1.827<br/>10010:1.84<br/>10011:1.853</p> |

| Offset: 0x0150 |            |             | Register Name: SYS_LDO_CTRL_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
|                |            |             | 10100:1.867                     |
|                |            |             | 10101:1.88                      |
|                |            |             | 10110:1.893                     |
|                |            |             | 10111:1.907                     |
|                |            |             | 11000:1.92                      |
|                |            |             | 11001:1.933                     |
|                |            |             | 11010:1.947                     |
|                |            |             | 11011:1.96                      |
|                |            |             | 11100:1.973                     |
|                |            |             | 11101:1.987                     |
|                |            |             | 11110:2                         |
|                |            |             | 11111:2.013                     |

### 3.5.3.5 0x0160 Resistor Calibration Control Register (Default Value: 0x0033\_0003)

| Offset: 0x0160 |            |             | Register Name: RESCAL_CTRL_REG                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:25          | /          | /           | /                                                                                                                                         |
| 24             | R/W        | 0x0         | Reserved                                                                                                                                  |
| 23:22          | /          | /           | /                                                                                                                                         |
| 21:16          | R/W        | 0x33        | Reserved                                                                                                                                  |
| 15:9           | /          | /           | /                                                                                                                                         |
| 8              | R/W        | 0x0         | DDR_RES240_Trimming_SEL<br>240ohms Resistor Trimming Source Select<br>0: Trimming value from RESCAL<br>1: Trimming value from RES240_TRIM |
| 7:3            | /          | /           | /                                                                                                                                         |
| 2              | R/W        | 0x0         | RESCAL_MODE<br>RESCAL Calibration Mode Select<br>0: Auto Calibration<br>1: Reserved                                                       |
| 1              | R/W        | 0x1         | CAL_ANA_EN.<br>Calibration Circuits Analog Enable<br>0: Disable<br>1: Enable                                                              |

| Offset: 0x0160 |            |             | Register Name: RESCAL_CTRL_REG                               |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 0              | R/W        | 0x1         | CAL_EN<br>Auto Calibration Enable<br>0: Disable<br>1: Enable |

### 3.5.3.6 0x0168 240ohms Resistor Manual Control Register (Default Value: 0x0000\_0033)

| Offset: 0x0168 |            |             | Register Name: RES240_CTRL_REG                   |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:6           | /          | /           | /                                                |
| 5:0            | R/W        | 0x33        | DDR_RES240_TRIM<br>240ohms Resistor trimming bit |

### 3.5.3.7 0x016C Resistor Calibration Status Register (Default Value: 0x0000\_0000)

| Offset: 0x016C |            |             | Register Name: RESCAL_STATUS_REG                   |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:9           | /          | /           | /                                                  |
| 8              | RO         | 0x0         | COUT<br>Calibration Circuits Analog Compare Output |
| 7:6            | /          | /           | /                                                  |
| 5:0            | RO         | 0x0         | RES_CAL_DO<br>RESCAL Calibration Results Output    |

## 3.6 RISC-V System

### 3.6.1 Overview

The RISC-V system includes RISC-V IP core and related peripheral devices (RISCV\_CFG, RISCV\_TIMESTAMP, Watchdog, PSENSOR, MSGBOX, BROM, and so on), which are interconnected by BUS Matrix.

The RISC-V system has the following features:

- RISC-V 64GCV instruction architecture
- The 5-level single engine executes the pipeline in sequence
- Instruction and data cache of the first level Harvard, 32 KB I-cache + 32 KB D-cache, 64 B cacheline
  - Instruction high-cache can configure parity, and data high-cache can configure ECC or parity
- Two-level TLB memory management unit to realize the virtual-real address translation and memory management
- Hardware automatic detection
- Supports AXI4.0 128-bit master interface
- Supports core-internal interrupt (CLINT) and interrupt controller (PLIC)
- Floating-point process unit
- Vector execution unit

### 3.6.2 Block Diagram

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

Figure 3-12 RISC-V System Block Diagram



### 3.6.3 Register List

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

| Register Name      | Offset | Description                   |
|--------------------|--------|-------------------------------|
| RISCV_STA_ADD0_REG | 0x0004 | RISCV Start Address0 Register |

| Register Name       | Offset | Description                         |
|---------------------|--------|-------------------------------------|
| RISCV_STA_ADD1_REG  | 0x0008 | RISCV Start Address1 Register       |
| RF1P_CFG_REG        | 0x0010 | RF1P Configuration Register         |
| ROM_CFG_REG         | 0x001C | ROM Configuration Register          |
| WAKEUP_EN_REG       | 0x0020 | Wakeup Enable Register              |
| WAKEUP_MASK0_REG    | 0x0024 | Wakeup Mask0 Register               |
| WAKEUP_MASK1_REG    | 0x0028 | Wakeup Mask1 Register               |
| WAKEUP_MASK2_REG    | 0x002C | Wakeup Mask2 Register               |
| WAKEUP_MASK3_REG    | 0x0030 | Wakeup Mask3 Register               |
| WAKEUP_MASK4_REG    | 0x0034 | Wakeup Mask4 Register               |
| TS_TMODE_SEL_REG    | 0x0040 | Timestamp Test Mode Select Register |
| SRAM_ADDR_TWIST_REG | 0x0044 | SRAM Address Twist Register         |
| WORK_MODE_REG       | 0x0048 | Work Mode Register                  |
| RETITE_PC0_REG      | 0x0050 | Retire PC0 Register                 |
| RETITE_PC1_REG      | 0x0054 | Retire PC1 Register                 |
| IRQ_MODE0_REG       | 0x0060 | IRQ Mode0 Register                  |
| IRQ_MODE1_REG       | 0x0064 | IRQ Mode1 Register                  |

| Register Name        | Offset | Description                            |
|----------------------|--------|----------------------------------------|
| IRQ_MODE2_REG        | 0x0068 | IRQ Mode2 Register                     |
| IRQ_MODE3_REG        | 0x006C | IRQ Mode3 Register                     |
| IRQ_MODE4_REG        | 0x0070 | IRQ Mode4 Register                     |
| RISCV_AXI_PMU_CTRL   | 0x0104 | RISCV AXI PMU Control Register         |
| RISCV_AXI_PMU_PRD    | 0x0108 | RISCV AXI PMU Period Register          |
| RISCV_AXI_PMU_LAT_RD | 0x010C | RISCV AXI PMU Read Latency Register    |
| RISCV_AXI_PMU_LAT_WR | 0x0110 | RISCV AXI PMU Write Latency Register   |
| RISCV_AXI_PMU_REQ_RD | 0x0114 | RISCV AXI PMU Read Request Register    |
| RISCV_AXI_PMU_REQ_WR | 0x0118 | RISCV AXI PMU Write Request Register   |
| RISCV_AXI_PMU_BW_RD  | 0x011C | RISCV AXI PMU Read Bandwidth Register  |
| RISCV_AXI_PMU_BW_WR  | 0x0120 | RISCV AXI PMU Write Bandwidth Register |

### 3.6.4 Register Description

#### 3.6.4.1 0x0004 RISCV Start Address0 Register (Default Value: 0x0000\_0000)

The 0x0004 register and 0x0008 register are grouped into a 40-bit address which is the running PC address after RISCV releases reset. Before releasing reset, this register should be configured. This register does support dynamic configuration.

| Offset: 0x0004 |            |             | Register Name: RISCV_STA_ADD0_REG                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:0           | R/W        | 0x00000000  | STA_ADD_L<br>Start Address Low 32-bit<br><br>The bit0 is fixed as 0 and can not be written. |

### 3.6.4.2 0x0008 RISCV Start Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: RISCV_STA_ADD1_REG      |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:8           | /          | /           | /                                      |
| 7:0            | R/W        | 0x00        | STA_ADD_H<br>Start Address High 8-bit. |

### 3.6.4.3 0x0010 RF1P Configuration Register (Default Value: 0x0000\_0013)

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

#### 3.6.4.4 0x001C ROM Configuration Register (Default Value: 0x0000\_0002)

| Offset: 0x001C |            |             | Register Name: ROM_CFG_REG   |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:8           | /          | /           | /                            |
| 7:0            | R/W        | 0x02        | ROM_CFG<br>ROM Configuration |

#### 3.6.4.5 0x0020 Wakeup Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: WAKEUP_EN_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:1           | /          | /           | /                            |
| 0              | R/W        | 0x0         | WP_EN<br>Wakeup Enable       |

#### 3.6.4.6 0x0024 Wakeup Mask0 Register (Default Value: 0x0000\_0000)

The 0x0024 to 0x0034 registers corresponds to the wakeup enable bits of 160 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1.

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

#### 3.6.4.7 0x0028 Wakeup Mask1 Register (Default Value: 0x0000\_0000)

The 0x0024 to 0x0034 registers corresponds to the wakeup enable bits of 160 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1.

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

#### 3.6.4.8 0x002C Wakeup Mask2 Register (Default Value: 0x0000\_0000)

The 0x0024 to 0x0034 registers corresponds to the wakeup enable bits of 160 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1.

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

#### 3.6.4.9 0x0030 Wakeup Mask3 Register (Default Value: 0x0000\_0000)

The 0x0024 to 0x0034 registers corresponds to the wakeup enable bits of 160 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1.

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

#### 3.6.4.10 0x0034 Wakeup Mask4 Register (Default Value: 0x0000\_0000)

The 0x0024 to 0x0034 registers corresponds to the wakeup enable bits of 160 interrupts. These wakeup enable bits are disabled by default. When some interrupt needs to be waken-up, the corresponding bit needs to be set to 1.

| Offset: 0x0034 |            |             | Register Name: WAKEUP_MASK4_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:0           | R/W        | 0x00000000  | WP_MASK4<br>Wakeup Mask4        |

#### 3.6.4.11 0x0040 Timestamp Test Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: TS_TMODE_SEL_REG                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:1           | /          | /           | /                                                                               |
| 0              | R/W        | 0x0         | TS_TEST_MODE_EN<br>Timestamp Test Mode Enable<br>0: Normal Mode<br>1: Test Mode |

### 3.6.4.12 0x0044 SRAM Address Twist Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SRAM_ADDR_TWIST_REG                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 31:16          | W          | UDF         | SRAM_TS_KF<br>SRAM Twist Keyfield<br><br>The bit 0 can be written only if this key field is written by 0x16AA.                                                                                                                                                                                                                                                   |
| 15:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 0              | R/W        | 0x0         | SRAM_ADDR_TS_FG.<br><br>SRAM Address Twist Flag.<br><br>When this bit is set up, the RISCV_BROM area would become invisible, and the start address of SRAM A1 would be twisted into 0x0, the original start address of SRAM A1 is 0x0002 0000. After the address has been twisted, RISCV reads data from 0x00020000 to 0x0002ffff as same as from 0x0 to 0xffff. |

### 3.6.4.13 0x0048 Work Mode Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: WORK_MODE_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:2           | /          | /           | /                            |

| Offset: 0x0048 |            |             | Register Name: WORK_MODE_REG                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 1:0            | R          | 0x0         | <p>WM_STA<br/>Work Mode Status<br/>00: Normal Mode<br/>01: Low Power Mode<br/>10: Debug Mode<br/>11: Reserved</p> |

#### 3.6.4.14 0x0050 Retire PC0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: RETITE_PC0_REG                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31:0           | R          | 0x0         | <p>RT_PC_L<br/>Retire PC[31:0]<br/>It indicates the current retiring instruction PC[31:0].</p> |

### 3.6.4.15 0x0054 Retire PC1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: RETITE_PC1_REG                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31             | R          | 0x0         | <p>RT_SIG<br/>Retire Signal<br/>0: The current period has not the retired instruction<br/>1: The current period has the retired instruction</p> |
| 30:8           | /          | /           |                                                                                                                                                 |
| 7:0            | R          | 0x0         | <p>RT_PC_H<br/>Retire PC[39:31]<br/>It indicates the current retiring instruction PC[39:31].</p>                                                |

### 3.6.4.16 0x0060 IRQ Mode0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: IRQ_MODE0_REG                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:0           | R/W        | 0x00000000  | <p>IRQ_MDO<br/>IRQ Mode0<br/>0: High-level trigger<br/>1: Rising edge trigger</p> |

### 3.6.4.17 0x0064 IRQ Mode1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: IRQ_MODE1_REG                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:0           | R/W        | 0x00000000  | <p>IRQ_MD1</p> <p>IRQ Mode1</p> <p>0: High-level trigger</p> <p>1: Rising edge trigger</p> |

### 3.6.4.18 0x0068 IRQ Mode2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: IRQ_MODE2_REG                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:0           | R/W        | 0x00000000  | <p>IRQ_MD2</p> <p>IRQ Mode2</p> <p>0: High-level trigger</p> <p>1: Rising edge trigger</p> |

### 3.6.4.19 0x006C IRQ Mode3 Register (Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: IRQ_MODE3_REG                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:0           | R/W        | 0x00000000  | <p>IRQ_MD3</p> <p>IRQ Mode3</p> <p>0: High-level trigger</p> <p>1: Rising edge trigger</p> |

### 3.6.4.20 0x0070 IRQ Mode4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: IRQ_MODE4_REG                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:0           | R/W        | 0x00000000  | <p>IRQ_MD4</p> <p>IRQ Mode4</p> <p>0: High-level trigger</p> <p>1: Rising edge trigger</p> |

**3.6.4.21 0x0104 RISCV AXI PMU Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x0104 |            |             | Register Name: RISCV_AXI_PMU_CTRL                         |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:2           | /          | /           | /                                                         |
| 1              | WC         | 0x0         | PMU_CLR<br>PMU Clear<br>0: No operation<br>1: PMU cleared |
| 0              | R/W        | 0x0         | PMU_EN<br>PMU Enable<br>0: PMU disabled<br>1: PMU enabled |

**3.6.4.22 0x0108 RISCV AXI PMU Period Register (Default Value: 0x0000\_0000)**

| Offset: 0x0108 |            |             | Register Name: RISCV_AXI_PMU_PRD                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:0           | R/W        | 0x0         | PRD<br>Monitor period<br>Suggest that the field is in units of 1us (1ms). |

### 3.6.4.23 0x010C RISCV AXI PMU Read Latency Register (Default Value: 0x0000\_0000)

| Offset: 0x10C |            |             | Register Name: RISCV_AXI_PMU_LAT_RD                                |
|---------------|------------|-------------|--------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                        |
| 31:0          | R          | 0x0         | LAT_RD<br>Monitor the total latency of read-channel durning period |

### 3.6.4.24 0x0110 RISCV AXI PMU Write Latency Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: RISCV_AXI_PMU_LAT_WR                                 |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:0           | R          | 0x0         | LAT_WR<br>Monitor the total latency of write-channel durning period |

### 3.6.4.25 0x0114 RISCV AXI PMU Read Request Register (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: RISCV_AXI_PMU_REQ_RD                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:0           | R          | 0x0         | REQ_RD<br>Monitor the total command numbers of read-channel durning period |

**3.6.4.26 0x0118 RISCV AXI PMU Write Request Register (Default Value: 0x0000\_0000)**

| Offset: 0x0118 |            |             | Register Name: RISCV_AXI_PMU_REQ_WR                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:0           | R          | 0x0         | REQ_WR<br>Monitor the total command numbers of write-channel durning period |

**3.6.4.27 0x011C RISCV AXI PMU Read Bandwidth Register (Default Value: 0x0000\_0000)**

| Offset: 0x011C |            |             | Register Name: RISCV_AXI_PMU_BW_RD                                  |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:0           | R          | 0x0         | BW_RD<br>Monitor the total data( KB) of read-channel durning period |

**3.6.4.28 0x0120 RISCV AXI PMU Write Bandwidth Register (Default Value: 0x0000\_0000)**

| Offset: 0x0120 |            |             | Register Name: RISCV_AXI_PMU_BW_WR                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | BW_WR<br>Monitor the total data( KB) of write-channel durning period |

## 3.7 Timer

### 3.7.1 Overview

The timer module implements the timing and counting functions. The timer module includes timer0, timer1, watchdog and audio video synchronization (AVS).

The timer0 and timer1 are completely consistent. The main features for timer0 and timer1 are as follows:

- Alternative count clock: LOSC or OSC24M. The LOSC can be either the internal or external low-frequency clock, and the external one has more accuracy.
- Supports 8 prescale factors
- Programmable 32-bit down timer
- Supports two timing modes: periodic mode and single counting mode
- Generates an interrupt when the count is decreased to 0

The watchdog is used to transmit a reset signal to reset the entire system when an exception occurs in the system. The main features for the watchdog are as follows:

- Single clock source: OSC24M/750
- Supports 12 initial values
- Supports the generation of timeout interrupts
- Supports the generation of reset signals
- Supports Watchdog Restart

The AVS is used to synchronize the audio and video. The AVS module includes AVS0 and AVS1, which are completely consistent. The main features for the AVS are as follows:

- Single clock source: OSC24M
- Programmable 33-bit up timer
- Supports updating the initial value anytime
- 12-bit frequency divider factor
- Supports Pause/Start function

### 3.7.2 Block Diagram

The following figure shows the functional block diagram of the timer module.

Figure 3-13 Timer Block Diagram



The watchdog, timer (including timer0 and timer1), and AVS are all mounted at the APB0 bus. The system configures the parameters of these configure registers via APB0 bus.

The timer and watchdog are both down counters and support generating interrupts after the counting value reaches 0.

For watchdog, the system is responsible for configuring the interval value. If the system fails to restart the watchdog regularly because of some exceptional situations, such as the bus hang, the watchdog will send out a Watchdog Reset External signal to reset the system. And the signal will be transmitted to the Reset pad to reset the PMIC.

### 3.7.3 Functional Description

#### 3.7.3.1 Timer

The timer (including timer0 and timer1) is a 32-bit down counter. The counter value is decremented by 1 on each rising edge of the timer clock.

The following figure shows the block diagram for the timer.

Figure 3-14 Block Diagram for the Timer



The clock source for the timer can be either OSC24M or LOSC. For LOSC, it can be either the internal or external low-frequency clock. The external one has more accuracy.

Each timer has a prescale that divides the working clock frequency by 1, 2, 4, 8, 16, 32, 64, or 128. And each timer can generate independent interrupts.

### Timing Modes

The timer has two timing modes: the single counting mode and periodic mode. You can configure the timing mode via the bit[7] of [TMRn\\_CTRL\\_REG](#) (n = 0 or 1). The value 0 is for the period mode and value 1 is for the single counting mode.

- Single Counting Mode

In the single counting mode, the timer starts counting from the interval value and generates an interrupt after the counter decreases to 0, and then stops counting. It starts to count again only when a new interval value is loaded.

- Periodic Mode

In the periodic mode, the timer restarts another round of counting after generating the interrupt. It reloads data from the [TMRn\\_INTV\\_VALUE\\_REG](#) and then continues to count.

### Formula for Calculating the Timer Time

The following formula describes the relationship among timer parameters.

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

Where,

The parameter n is either 0 or 1;

$T_{\text{timer}}$  is the remaining time of the timer;

$\text{TMRn\_INTV\_VALUE\_REG}$  is the interval value of the timer;

$\text{TMRn\_CUR\_VALUE\_REG}$  is the current value of the timer;

$\text{TMRn\_CLK\_SRC}$  is the frequency of the timer clock source;

$\text{TMRn\_CLK\_PRES}$  is the prescale ratio of the timer clock.

### Initializing the Timer

Follow the steps below to initialize the timer:

1. Configure the timer parameters clock source, prescale factor, and timing mode by writing [TMRn\\_CTRL\\_REG](#). There is no sequence requirement of configuring the parameters.

2. Write the interval value.
  - a) Write [TMRn INTV VALUE REG](#) to configure the interval value for the timer.
  - b) Write bit[1] of [TMRn CTRL REG](#) to load the interval value to the timer. The value of the bit will be cleared automatically after loading the interval value.
3. Write bit[0] of [TMRn CTRL REG](#) to start the timer. To get the current value of the timer, read [TMRn CUR VALUE REG](#).

### Processing the Interrupt

Follow the steps below to process the interrupt:

1. Enable interrupts for the timer: write the enable bit of the corresponding interrupt in [TMR IRQ EN REG](#) for the timer. The timer will generate an interrupt everytime the count value reaches 0.
2. After entering the interrupt process, write the pending bit of the corresponding interrupt in [TMR IRQ STA REG](#) to clear the interrupt pending, and execute the process of waiting for the interrupt.
3. Resume the interrupt and continue to execute the interrupted process.

#### 3.7.3.2 Watchdog

The watchdog is a 32-bit down counter. The counter value is decremented by 1 on each rising edge of the count clock.

The following figure shows the block diagram for the watchdog.

**Figure 3-15 Block Diagram for the Watchdog**



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

## Operating Modes

The watchdog has two operating modes: the interrupt mode and reset mode.

- In the interrupt mode, when the counter value reaches 0 and WDOG\_IRQ\_EN\_REG is enabled, the watchdog generates an interrupt.
- In the reset mode, when the counter value reaches 0, the watchdog generates a reset signal to reset the entire system.

You can configure the operating mode for the watchdog via the bit[1:0] of the WDOG\_CFG\_REG. The value 0x2 is for the interrupt mode and the value 0x1 is for the reset mode.

Both the interrupt mode and reset mode support Watchdog Restart. You can make the watchdog to count from the initial value at any time by configuring the WDOG\_CTRL\_REG: write 0xA57 to bit[12:1], then write 1 to bit[0].

## Initializing the Watchdog

Follow the steps below to initialize the watchdog:

1. Write the bit[1:0] of [WDOG\\_CFG\\_REG](#) to configure the watchdog operating mode so that the watchdog can generate interrupts or output reset signals.
2. Write the bit[7:4] of [WDOG\\_MODE\\_REG](#) to configure the initial count value.
3. Write the bit[0] of [WDOG\\_MODE\\_REG](#) to enable the watchdog.

## Processing the Interrupt

In the interrupt mode, the watchdog is used as a counter. It generates an interrupt everytime the count value reaches 0.

Follow the steps below to process the interrupt:

1. Write the enable bit of [WDOG\\_IRQ\\_EN\\_REG](#) to enable the interrupt.
2. After entering the interrupt process, write the pending bit of [WDOG\\_IRQ\\_STA\\_REG](#) to clear the interrupt pending and execute the process of waiting for the interrupt.
3. Resume the interrupt and continue to execute the interrupted process.

### 3.7.3.3 AVS

The AVS is a 33-bit up counter. The counter value is increased by 1 on each rising edge of the count clock. There is a clock gate in [CCU](#) module to control the output of the AVS counter. To operate the AVS, open the clock gate first.

The following figure shows the block diagram for the AVS.

**Figure 3-16 Block Diagram for the AVS**



The clock source of the AVS is OSC24M. There is a 12-bit division factor for each AVS, N0 for AVS0 and N1 for AVS1. When the timer increases from 0 to N1 or N2, the AVS counter adds 1. When the counter reaches 33-bit upper limit, the AVS will start to count from the initial value again.

The AVS supports changing the initial value and division factor at anytime. And the AVS supports restarting from the initial value or pausing at anytime.

#### Starting or Pausing the AVS

Follow the steps below:

1. Write [AVS\\_CNT\\_DIV\\_REG](#) to configure the division factor.
2. Write [AVS\\_CNTn\\_REG](#) ( $n = 0$  or  $1$ ) to configure the initial value.
3. Write [AVS\\_CNT\\_CTL\\_REG](#) to enable the AVS. You can pause the AVS at any time.

### 3.7.4 Programming Guidelines

#### 3.7.4.1 Configuring the Timer

The following example shows how to make a one-millisecond delay with the clock source selected as OSC24M, the operating mode sets as single counting mode, and the pre-scale sets as 2.

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

```
writel(readl(TMR_0_CTRL)|(1<<0), TMR_0_CTRL); //Enable Timer0
```

### 3.7.4.2 Resetting the Watchdog

The following example shows how to make the watchdog to generate a reset signal to the whole system after 1 second. The clock source for the watchdog is OSC24M/750.

```
writel(0x1, WDOG_CONFIG); //Set the operating mode as the reset mode.  
writel(0x10, WDOG_MODE); //Set the interval value as 1 s.  
writel(readl(WDOG_MODE)|(1<<0), WDOG_MODE); //Enable the Watchdog.
```

### 3.7.4.3 Restarting the Watchdog

The following example shows how to restart the watchdog. In this example, the clock source is OSC24M/750, the interval value is 1 second, and the watchdog operating mode is the reset mode.

If the execution time of “other codes” is shorter than 1 second, the watchdog will restart from the interval value before it count to zero and generates the reset signal. Otherwise, the watchdog will reset the whole system before the code “writel(readl(WDOG\_CTRL)|(0xA57<<1)|(1<<0), WDOG\_CTRL)” is executed.

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

## 3.7.5 Register List

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

| Register Name   | Offset | Description               |
|-----------------|--------|---------------------------|
| TMR_IRQ_EN_REG  | 0x0000 | Timer IRQ Enable Register |
| TMR_IRQ_STA_REG | 0x0004 | Timer Status Register     |

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

### 3.7.6 Register Description

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

| Offset: 0x0000 |            |             | Register Name: TMR_IRQ_EN_REG                                       |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:2           | /          | /           | /                                                                   |
| 1              | R/W        | 0x0         | TMR1_IRQ_EN<br>Timer1 Interrupt Enable<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | TMRO_IRQ_EN<br>Timer0 Interrupt Enable<br>0: Disabled<br>1: Enabled |

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

| Offset: 0x0004 |            |             | Register Name: TMR_IRQ_STA_REG                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:2           | /          | /           | /                                                                                                                                                                                              |
| 1              | R/W1C      | 0x0         | <p>TMR1_IRQ_PEND<br/>The IRQ pending bit for Timer1<br/>0: No effect<br/>1: Pending, indicates that the interval value of the timer 1 is reached.<br/>Write 1 to clear the pending status.</p> |
| 0              | R/W1C      | 0x0         | <p>TMR0_IRQ_PEND<br/>The IRQ pending bit for Timer0<br/>0: No effect<br/>1: Pending, indicates that the interval value of the timer 0 is reached.<br/>Write 1 to clear the pending status.</p> |

### 3.7.6.3 0x0010 Timer0 Control Register (Default Value: 0x0000\_0004)

| Offset: 0x0010 |            |             | Register Name: TMRO_CTRL_REG                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                             |
| 7              | R/W        | 0x0         | <p>TMRO_MODE<br/>Select the timing mode for timer0<br/>0: Periodic mode. When the interval value of the timer 0 is reached, the timer will restart another round of counting automatically.<br/>1: Single counting mode. When the interval value of the timer 0 is reached, the timer will stop counting.</p> |

| Offset: 0x0010 |            |             | Register Name: TMRO_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6:4            | R/W        | 0x0         | <p>TMRO_CLK_PRES<br/>Select the pre-scale of timer0 clock source</p> <p>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:2            | R/W        | 0x1         | <p>TMRO_CLK_SRC<br/>Select the clock source for timer0</p> <p>00: LOSC<br/>01: OSC24M<br/>10: /<br/>11: /</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1              | R/W        | 0x0         | <p>TMRO_RELOAD<br/>Timer0 Reload</p> <p>0: No effect<br/>1: Reload the Interval value for timer0</p> <p>After the bit is set, it can not be written again before it is cleared automatically.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0              | R/W        | 0x0         | <p>TMRO_EN<br/>Timer0 Enable</p> <p>0: Stop/Pause<br/>1: Start</p> <p>By setting the bit to 1, the timer will be started. It reloads the interval value register and then counts from the interval value to 0.</p> <p>By setting the bit to 0 before the timer counts to 0, the timer will be paused. The bit will be locked to 0 for at least 2 cycles. Within the 2 cycles, you cannot set the bit to 1 to restart the timer.</p> <p>The timer supports updating the interval value in the pause state. To start to down-count from the updated interval value, set both the reload bit and enable bit to 1.</p> <p>Additionally, in the single counting mode, after the count value reaches 0, the system will automatically change the bit to 0 to stop the timer.</p> |

### 3.7.6.4 0x0014 Timer0 Interval Value Register (Default Value: 0x0000\_0000)

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


**NOTE**

Take the system clock and timer clock source into consideration when setting the interval value.

### 3.7.6.5 0x0018 Timer0 Current Value Register (Default Value: 0x0000\_0000)

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

### 3.7.6.6 0x0020 Timer1 Control Register (Default Value: 0x0000\_0004)

| Offset: 0x0020 |            |             | Register Name: TMR1_CTRL_REG                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                   |
| 7              | R/W        | 0x0         | TMR1_MODE<br>Select the timing mode for timer1<br>0: Periodic mode. When the interval value of the timer 1 is reached, the timer will restart another round of counting automatically.<br>1: Single counting mode. When the interval value of the timer 1 is reached, the timer will stop counting. |

| Offset: 0x0020 |            |             | Register Name: TMR1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:4            | R/W        | 0x0         | <p>TMR1_CLK_PRES<br/>Select the pre-scale of timer1 clock source</p> <p>000: /1<br/>001: /2<br/>010: /4<br/>011: /8<br/>100: /16<br/>101: /32<br/>110: /64<br/>111: /128</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:2            | R/W        | 0x1         | <p>TMR1_CLK_SRC<br/>Select the pre-scale of timer1 clock source</p> <p>00: LOSC<br/>01: OSC24M<br/>10: /<br/>11: /</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1              | R/W        | 0x0         | <p>TMR1_RELOAD<br/>Timer1 Reload<br/>0: No effect<br/>1: Reload the interval value for timer1<br/>After the bit is set, it can not be written again before it is cleared automatically.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | R/W        | 0x0         | <p>TMR1_EN<br/>Timer1 Enable<br/>0: Stop/Pause<br/>1: Start<br/>By setting the bit to 1, the timer will be started. It reloads the interval value register and then counts from the interval value to 0.<br/>By setting the bit to 0 before the timer counts to 0, the timer will be paused. The bit will be locked to 0 for at least 2 cycles. Within the 2 cycles, you cannot set the bit to 1 to restart the timer.<br/>The timer supports updating the interval value in the pause state. To start to down-count from the updated interval value, set both the reload bit and enable bit to 1.<br/>Additionally, in the single counting mode, after the count value reaches 0, the system will automatically change the bit to 0 to stop the timer.</p> |

### 3.7.6.7 0x0024 Timer1 Interval Value Register (Default Value: 0x0000\_0000)

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

**NOTE**

Take the system clock and timer clock source into consideration when setting the interval value.

### 3.7.6.8 0x0028 Timer1 Current Value Register (Default Value: 0x0000\_0000)

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

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

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

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

| Offset: 0x00A4 |            |             | Register Name: WDOG_IRQ_STA_REG                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
| 31:1           | /          | /           | /                                                                                                                                                                                                     |
| 0              | R/W1C      | 0x0         | <p>WDOG_IRQ_PEND<br/>The IRQ pending bit for the watchdog<br/>Write 1 to clear the pending status.<br/>0: No effect<br/>1: Pending, indicates that the interval value of the watchdog is reached.</p> |

### 3.7.6.11 0x00A8 Watchdog Software Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x00A8 |            |             | Register Name: WDOG_SOFT_RST_REG                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:16          | W          | 0x0         | <p>KEY_FIELD<br/>Key Field<br/>To change the value of bit[0], this field should be filled with 0x16AA.</p>                                                      |
| 15:1           | /          | /           | /                                                                                                                                                               |
| 0              | R/W1C      | 0x0         | <p>Soft Reset Enable<br/>0: De-assert<br/>1: Reset the system<br/><b>Note: To use the bit to reset the system, the watchdog first needs to be disabled.</b></p> |

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

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

| Offset: 0x00B0 |            |             | Register Name: WDOG_CTRL_REG                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 0              | R/W1S      | 0x0         | <p>WDOG_RESTART<br/>Watchdog Restart<br/>0: No effect<br/>1: Restart the watchdog</p> |

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

| Offset: 0x00B4 |            |             | Register Name: WDOG_CFG_REG                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:16          | W          | 0x0         | <p>KEY_FIELD<br/>Key Field<br/>To change the value of bit[15:0], this field should be filled with 0x16AA.</p>                                                                                        |
| 15:9           | /          | /           | /                                                                                                                                                                                                    |
| 8              | R/W        | 0x0         | <p>WDOG_CLK_SRC<br/>Select the clock source for the watchdog.<br/>0: HOSC_32K, that is, OSC24M/750. It is a 32 KHz clock divided from the OSC24M.<br/>1: LOSC_32K. A clock provided by the LOSC.</p> |
| 7:2            | /          | /           | /                                                                                                                                                                                                    |
| 1:0            | R/W        | 0x1         | <p>WDOG_MODE<br/>Configure the operating mode for the watchdog<br/>00: /<br/>01: To whole system<br/>10: Only interrupt mode<br/>11: /</p>                                                           |

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

| Offset: 0x00B8 |            |             | Register Name: WDOG_MODE_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:16          | W          | 0x0         | <p>KEY_FIELD<br/>Key Field<br/>To change the value of bit[15:0], this field should be filled with 0x16AA.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:4            | R/W        | 0x0         | <p>WDOG_INTV_VALUE<br/>Watchdog Interval Value<br/>0000: 16000 cycles (0.5 s)<br/>0001: 32000 cycles (1 s)<br/>0010: 64000 cycles (2 s)<br/>0011: 96000 cycles (3 s)<br/>0100: 128000 cycles (4 s)<br/>0101: 160000 cycles (5 s)<br/>0110: 192000 cycles (6 s)<br/>0111: 256000 cycles (8 s)<br/>1000: 320000 cycles (10 s)<br/>1001: 384000 cycles (12 s)<br/>1010: 448000 cycles (14 s)<br/>1011: 512000 cycles (16 s)<br/>Others: Reserved<br/><b>Note: The corresponding clock cycles for the interval value (IV) depends on the frequency of the clock: Cycles = F<sub>CLK</sub> * IV.</b><br/>For example, to get a interval value of 0.5 second, if the clock source is HOSC_32K (whose frequency is 32 KHz), the cycle number is 16,000; if the clock source is LOSC_32K (whose frequency is 32.768 kHz), the cycle number is 16,384.</p> |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | R/W        | 0x0         | <p>WDOG_EN<br/>Watchdog Enable<br/>0: No effect<br/>1: Enable the Watchdog</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 3.7.6.15 0x00BC Watchdog Output Configuration Register (Default Value: 0x0000\_001F)

| Offset: 0x00BC |            |             | Register Name: WDOG_OUTPUT_CFG_REG                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31:12          | /          | /           | /                                                                                                                                                                         |
| 11:0           | R/W        | 0x1F        | <p>WDOG OUTPUT CONFIG</p> <p>Configure the valid time for the watchdog reset signal.</p> <p><math>T = 1/32\text{ms}^*(N + 1)</math></p> <p>The default value is 1 ms.</p> |

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

| Offset: 0x00C0 |            |             | Register Name: AVS_CNT_CTL_REG                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:10          | /          | /           | /                                                                                                                                           |
| 9              | R/W        | 0x0         | <p>AVS_CNT1_PS</p> <p>Audio/Video Sync Counter 1 Pause Control</p> <p>0: Do not pause.</p> <p>1: Pause the AVS counter1.</p>                |
| 8              | R/W        | 0x0         | <p>AVS_CNT0_PS</p> <p>Audio/Video Sync Counter 0 Pause Control</p> <p>0: Do not pause.</p> <p>1: Pause the AVS counter0.</p>                |
| 7:2            | /          | /           | /                                                                                                                                           |
| 1              | R/W        | 0x0         | <p>AVS_CNT1_EN</p> <p>Audio/Video Sync Counter 1 Enable/Disable</p> <p>The clock source is OSC24M.</p> <p>0: Disabled</p> <p>1: Enabled</p> |
| 0              | R/W        | 0x0         | <p>AVS_CNT0_EN</p> <p>Audio/Video Sync Counter 0 Enable/Disable</p> <p>The clock source is OSC24M.</p> <p>0: Disabled</p> <p>1: Enabled</p> |

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

| Offset: 0x00C4 |            |             | Register Name: AVS_CNT0_REG                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:0           | R/W        | 0x0         | <p>AVS_CNT0</p> <p>The higher 32 bits of AVS counter0.</p> <p>AVS counter0 is a 33-bit up counter. The initial value consists of two parts: this register forms the bit[32:1] of AVS counter0 and the bit[0] is zero.</p> <p>You can set the initial value of the AVS counter0 by software. The initial value can be updated at anytime. You can also pause the counter by setting AVS_CNT0_PS to "1". The counter value will not increase when it is paused.</p> |

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

| Offset: 0x00C8 |            |             | Register Name: AVS_CNT1_REG                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:0           | R/W        | 0x0         | <p>AVS_CNT1</p> <p>The higher 32 bits of AVS counter1.</p> <p>AVS counter1 is a 33-bit up counter. The initial value consists of two parts: this register forms the bit[32:1] of AVS counter0 and the bit[0] is zero.</p> <p>You can set the initial value of the AVS counter1 by software. The initial value can be updated at anytime. You can also pause the counter by setting AVS_CNT1_PS to "1". The counter value will not increase when it is paused.</p> |

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

| Offset: 0x00CC |            |             | Register Name: AVS_CNT_DIV_REG |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:28          | /          | /           | /                              |

| Offset: 0x00CC |            |             | Register Name: AVS_CNT_DIV_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27:16          | R/W        | 0x5DB       | <p>AVS_CNT1_D</p> <p>N1, the divisor factor for AVS1.</p> <p>The clock for AVS1 is 24 MHz/N1.</p> <p><math>N1 = \text{Bit}[27:16] + 1</math>.</p> <p>The valid value for N1 is from 1 to 0x7ff.</p> <p>There is an internal 12-bit counter maintained by the engine of the 33-bit AVS1. The 12-bit counter is used for counting the cycle number of the clock OSC24M. When the value of the 12-bit counter reaches N1, the internal 33-bit counter register will increase 1 and the 12-bit counter will reset to zero and restart again.</p> <p>You can change the value of N1 via the software at any time.</p> |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11:0           | R/W        | 0x5DB       | <p>AVS_CNT0_D</p> <p>N0, the divisor factor for AVS0.</p> <p>The clock for AVS0 is 24MHz/N0.</p> <p><math>N0 = \text{Bit}[11:0] + 1</math>.</p> <p>The valid value for N0 is from 1 to 0x7ff.</p> <p>There is an internal 12-bit counter maintained by the engine of the 33-bit AVS0. The 12-bit counter is used for counting the cycle number of the clock OSC24M. When the value of the 12-bit counter reaches N0, the internal 33-bit counter register will increase 1 and the 12-bit counter will reset to zero and restart again.</p> <p>You can change the value of N0 via the software at any time.</p>   |

## 3.8 High Speed Timer

### 3.8.1 Overview

The high speed timer (HSTimer) module consists of HSTimer0 and HSTimer1. HSTimer0 and HSTimer1 are down counters that implement timing and counting functions. They are completely consistent. Compared with the timer module, the HSTimer module provides more precise timing and counting.

The HSTimer has the following features:

- Single clock source: AHB0
- Supports 5 prescale factors
- Configurable 56-bit down timer
- Supports 2 timing modes: periodic mode and one-shot mode
- Supports the test mode
- Generates an interrupt when the count is decreased to 0

### 3.8.2 Block Diagram

The following figure shows the block diagram of the HSTimer.

Figure 3-17 HSTimer Block Diagram



### 3.8.3 Functional Description

The HSTimers are 56-bit down counters. The counter value is decremented by 1 on each rising edge of the count clock. Each HSTimer has a prescaler that divides the working clock frequency of each working timer by 1, 2, 4, 8, or 16.

#### 3.8.3.1 Typical Application

The following figure shows a typical application of HSTimer module.

**Figure 3-18 Typical Application for HSTimer**

The HSTimer module is mounted at AHBO, and can control the registers via AHBO. AHBO is the clock source of the HSTimer. When the count value reaches zero, the HSTimer generates an interrupt.

### 3.8.3.2 Count Modes

The HSTimer has two count modes: one-shot mode and periodic mode. You can configure the timing mode via the bit[7] of [HS\\_TMRn\\_CTRL\\_REG](#) ( $n = 0$  or  $1$ ). The value 0 is for the period mode and value 1 is for the one-shot mode.

- One-shot Mode

When the count value of the HSTimer reaches 0, the HSTimer stops counting. The HSTimer starts to count again only when a new value is loaded.

- Periodic Mode

The HSTimer counts continuously. When the count value of the HSTimer reaches 0, the HSTimer reloads an initial value from [HS\\_TMRn\\_INTV\\_LO\\_REG](#) and [HS\\_TMRn\\_INTV\\_HI\\_REG](#) and then continues to count.

### 3.8.3.3 Operating Modes

The HSTimer has two operating modes: the normal mode and test mode. You can configure the operating mode via the bit[31] of [HS\\_TMRn\\_CTRL\\_REG](#). The value 0 is for the normal mode and value 1 is for the test mode.

- Normal Mode

In the normal mode, the HSTimer is used as a 56-bit down counter, which can finish one-shot counting and periodic counting. The interval value for the HSTimer consists of two parts: [HS\\_TMRn\\_INTV\\_LO\\_REG](#) forms the bit[31:0] and [HS\\_TMRn\\_INTV\\_HI\\_REG](#) forms the bit[55:32]. To read or write the interval value, [HS\\_TMRn\\_INTV\\_LO\\_REG](#) should be done before [HS\\_TMRn\\_INTV\\_HI\\_REG](#).

- Test Mode

In the test mode, the HSTimer is used as a 24-bit down counter. HS\_TMRn\_INTV\_LO\_REG must be set to 0x1, and HS\_TMRn\_INTV\_HI\_REG acts as the initial value for the HSTimer.

### 3.8.3.4 HSTimer Formula

The following formula describes the relationship among HSTimer parameters in the normal mode.

$$T_{HSTimer} = \frac{(HS\_TMRn\_INTV\_HI\_REG << 32 + HS\_TMRn\_INTV\_LO\_REG) - (HS\_TMRn\_CURNT\_HI\_REG << 32 + HS\_TMRn\_CURNT\_LO\_REG)}{AHB0CLK} \times HS\_TMRn\_CLK$$

Where,

The parameter n is either 0 or 1;

$T_{HSTimer}$  is the remaining time of the timer;

$HS\_TMRn\_INTV\_HI\_REG$  is bit[55:32] of the HSTimer interval value;

$HS\_TMRn\_INTV\_LO\_REG$  is bit[31:0] of the HSTimer interval value;

$HS\_TMRn\_CURNT\_HI\_REG$  is bit[55:32] of the HSTimer current value;

$HS\_TMRn\_CURNT\_LO\_REG$  is bit[31:0] of the HSTimer current value;

AHB0CLK is the frequency of AHB0 Clock (the HSTimer clock source);

$HS\_TMRn\_CLK$  is the prescale ratio of the HSTimer clock.

### 3.8.3.5 Initializing the HSTimer

The following figure shows the process of HSTimer initialization.

**Figure 3-19 HSTimer Initialization Process**

1. AHBO clock management: Open the clock gate of AHBO and de-assert the soft reset of AHBO in CCU.
2. Configure the corresponding parameters of the HSTimer: clock source, prescaler factor, operating mode, and timing mode. There is no sequence requirement when writing the above parameters to [HS\\_TMRn\\_CTRL\\_REG](#).
3. Write the initial value: Write the lower 32 bits of the initial value to [HS\\_TMRn\\_INTV\\_LO\\_REG](#) first, and then the higher 24 bits to [HS\\_TMRn\\_INTV\\_HI\\_REG](#). Normally, write the bit[1] of [HS\\_TMRn\\_CTRL\\_REG](#) to load the initial value. If the HSTimer is in the timing stop stage, write 1 to the bit[1] and bit[0] of [HS\\_TMRn\\_CTRL\\_REG](#) at the same time to reload the initial value.
4. Enable HSTimer: Write the bit[0] of [HS\\_TMRn\\_CTRL\\_REG](#) to enable HSTimer to count.
5. Reading [HS\\_TMRn\\_CURNT\\_LO\\_REG](#) and [HS\\_TMRn\\_CURNT\\_HI\\_REG](#) can get current counting value.

### 3.8.3.6 Processing the HSTimer Interrupt

Follow the steps below to process the HSTimer interrupt:

1. Enable interrupt: Write the corresponding interrupt enable bit of [HS\\_TMR IRQ\\_EN\\_REG](#), when the counting time of HSTimer reaches, the corresponding interrupt generates.
2. After entering the interrupt process, write [HS\\_TMR IRQ\\_STAS\\_REG](#) to clear the interrupt pending.
3. Resume the interrupt and continue to execute the interrupted process.

### 3.8.4 Programming Guidelines

The following example shows how to make a 1 us delay with HSTimer0. The frequency of the AHBO clock is 100 MHz, the operating mode is the normal mode, the timing mode is single counting mode, and the pre-scale is 2.

```
writel(0x32, HS_TMR0_INTV_LO);           //Set bit[31:0] of the interval value as 0x32.  
writel(0x0, HS_TMR0_INTV_HI);           //Set bit[55:32] of the interval value as 0x0.  
  
writel(0x90, HS_TMR0_CTRL);  
//Set the operating mode as Normal Mode, the pre-scale as 2, and the timing mode as Single Counting Mode.  
  
writel(readl(HS_TMR0_CTRL)|(1<<1), HS_TMR0_CTRL); //Set the reload bit.  
writel(readl(HS_TMR0_CTRL)|(1<<0), HS_TMR0_CTRL); //Enable HSTimer0.  
  
while(!(readl(HS_TMR_IRQ_STAS)&1));        //Wait for HSTimer0 to generate pending.  
writel(1, HS_TMR_IRQ_STAS);                //Clear HSTimer0 pending.
```

### 3.8.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| HSTimer     | 0x03008000   |

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

### 3.8.6 Register Description

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

| Offset: 0x0000 |            |             | Register Name: HS_TMR_IRQ_EN_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:2           | /          | /           | /                                                                        |
| 1              | R/W        | 0x0         | HS_TMR1_INT_EN<br>HSTimer1 Interrupt Enable<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | HS_TMR0_INT_EN<br>HSTimer0 Interrupt Enable<br>0: Disabled<br>1: Enabled |

#### 3.8.6.2 0x0004 HS Timer IRQ Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: HS_TMR_IRQ_STAS_REG                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:2           | /          | /           | /                                                                                                                                                                                                             |
| 1              | R/W1C      | 0x0         | HS_TMR1_IRQ_PEND<br>HSTimer1 IRQ Pending<br>The IRQ pending bit for HSTimer1. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending, indicates that the initial value of the HSTimer is reached. |
| 0              | R/W1C      | 0x0         | HS_TMR0_IRQ_PEND<br>HSTimer0 IRQ Pending<br>The IRQ pending bit for HSTimer0. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending, indicates that the initial value of the HSTimer is reached. |

## 3.8.6.3 0x0020 HS Timer0 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: HS_TMR0_CTRL_REG                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | HS_TMR0_TEST<br>Select the operating mode for HSTimer0<br>0: Normal mode<br>1: Test mode<br>In the test mode, the <b>HS_TMR0_INTV_LO_REG</b> must be set to 0x1, and <b>HS_TMR0_INTV_HI_REG</b> acts as the initial value for HSTimer0.                                     |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                                                           |
| 7              | R/W        | 0x0         | HS_TMR0_MODE<br>Select the timing mode for HSTimer0<br>0: Periodic mode. When the count value is decreased to 0, the timer will restart another round of counting automatically.<br>1: One-shot mode. When the count value is decreased to 0, the timer will stop counting. |
| 6:4            | R/W        | 0x0         | HS_TMR0_CLK<br>Select the pre-scale for the HSTimer0 clock sources<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /<br>110: /<br>111: /                                                                                                                    |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                           |
| 1              | R/W1S      | 0x0         | HS_TMR0_RELOAD<br>HSTimer0 Reload<br>0: No effect<br>1: Reload the interval value of the HSTimer0                                                                                                                                                                           |

| Offset: 0x0020 |            |             | Register Name: HS_TMR0_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0              | R/W        | 0x0         | <p>HS_TMR0_EN<br/>HSTimer0 Enable<br/>0: Stop/Pause<br/>1: Start</p> <p>By setting the bit to 1, the timer will be started. It reloads the interval value register and then counts from the interval value to 0.</p> <p>By setting the bit to 0 before the timer counts to 0, the timer will be paused. The bit will be locked to 0 for at least 2 cycles. Within the 2 cycles, you cannot set the bit to 1 to restart the timer.</p> <p>The timer supports updating the interval value in the pause state. To start from the updated interval value, set both the reload bit and enable bit to 1.</p> <p>Additionally, in the one-shot mode, after the count value reaches 0, the system will automatically change the bit to 0 to stop the timer.</p> |

### 3.8.6.4 0x0024 HS Timer0 Interval Value Lo Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: HS_TMR0_INTV_LO_REG                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:0           | R/W        | 0x0         | <p>HS_TMR0_INTV_VALUE_LO<br/>Bit[31:0] of the HSTimer0 interval value.</p> |

### 3.8.6.5 0x0028 HS Timer0 Interval Value Hi Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: HS_TMR0_INTV_HI_REG                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:24          | /          | /           | /                                                                           |
| 23:0           | R/W        | 0x0         | <p>HS_TMR0_INTV_VALUE_HI<br/>Bit[55:32] of the HSTimer0 interval value.</p> |



HSTimer0 is a 56-bit counter. The interval value consists of two parts: HS\_TMR0\_INTV\_VALUE\_LO acts as the bit[31:0] and HS\_TMR0\_INTV\_VALUE\_HI acts as the bit[55:32]. To read or write the interval value, HS\_TMR0\_INTV\_LO\_REG should be done before HS\_TMR0\_INTV\_HI\_REG.

### 3.8.6.6 0x002C HS Timer0 Current Value Lo Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: HS_TMR0_CURNT_LO_REG                              |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:0           | R/W        | 0x0         | HS_TMR0_CUR_VALUE_LO<br>Bit[31:0] of the HSTimer0 current value. |

### 3.8.6.7 0x0030 HS Timer0 Current Value Hi Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: HS_TMR0_CURNT_HI_REG                               |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31:24          | /          | /           | /                                                                 |
| 23:0           | R/W        | 0x0         | HS_TMR0_CUR_VALUE_HI<br>Bit[55:32] of the HSTimer0 current value. |



HSTimer0 is a 56-bit counter. The current value consists of two parts: HS\_TMR0\_CUR\_VALUE\_LO acts as the bit[31:0] and HS\_TMR0\_CUR\_VALUE\_HI acts as the bit[55:32]. To read or write the current value, HS\_TMR0\_CUR\_VALUE\_LO should be done before HS\_TMR0\_CUR\_VALUE\_HI.

### 3.8.6.8 0x0040 HS Timer1 Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: HS_TMR1_CTRL_REG                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0x0         | <b>HS_TMR1_TEST</b><br>Select the operating mode for HSTimer1.<br>0: Normal mode<br>1: Test mode<br>In the test mode, the <b>HS_TMR1_INTV_LO_REG</b> must be set to 0x1, and <b>HS_TMR1_INTV_HI_REG</b> acts as the interval value for HSTimer1.                                    |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 7              | R/W        | 0x0         | <b>HS_TMR1_MODE</b><br>Select the timing mode for HSTimer1.<br>0: Periodic mode. When the count value is decreased to 0, the timer will restart another round of counting automatically.<br>1: One-shot mode. When the count value is decreased to 0, the timer will stop counting. |
| 6:4            | R/W        | 0x0         | <b>HS_TMR1_CLK</b><br>Select the pre-scale of the HSTimer1 clock sources.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /<br>110: /<br>111: /                                                                                                                     |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 1              | R/W1S      | 0x0         | <b>HS_TMR1_RELOAD</b><br>HSTimer1 Reload<br>0: No effect<br>1: Reload the HSTimer1 interval value.                                                                                                                                                                                  |

| Offset: 0x0040 |            |             | Register Name: HS_TMR1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0              | R/W        | 0x0         | <p>HS_TMR1_EN<br/>HSTimer1 Enable<br/>0: Stop/Pause<br/>1: Start</p> <p>By setting the bit to 1, the timer will be started. It reloads the interval value register and then counts from the interval value to 0.</p> <p>By setting the bit to 0 before the timer counts to 0, the timer will be paused. The bit will be locked to 0 for at least 2 cycles. Within the 2 cycles, you cannot set the bit to 1 to restart the timer.</p> <p>The timer supports updating the interval value in the pause state. To start from the updated interval value, set both the reload bit and enable bit to 1.</p> <p>Additionally, in the one-shot mode, after the count value reaches 0, the system will automatically change the bit to 0 to stop the timer.</p> |

### 3.8.6.9 0x0044 HS Timer1 Interval Value Lo Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: HS_TMR1_INTV_LO_REG                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:0           | R/W        | 0x0         | <p>HS_TMR1_INTV_VALUE_LO<br/>Bit[31:0] of the HSTimer1 interval value</p> |

### 3.8.6.10 0x0048 HS Timer1 Interval Value Hi Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: HS_TMR1_INTV_HI_REG                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:24          | /          | /           | /                                                                          |
| 23:0           | R/W        | 0x0         | <p>HS_TMR1_INTV_VALUE_HI<br/>Bit[55:32] of the HSTimer1 interval value</p> |

**NOTE**

HSTimer1 is a 56-bit counter. The interval value consists of two parts: HS\_TMR1\_INTV\_VALUE\_LO acts as the bit[31:0] and HS\_TMR1\_INTV\_VALUE\_HI acts as the bit[55:32]. To read or write the interval value, HS\_TMR1\_INTV\_LO\_REG should be done before HS\_TMR1\_INTV\_HI\_REG.

### 3.8.6.11 0x004C HS Timer1 Current Value Lo Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: HS_TMR1_CURNT_LO_REG                             |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:0           | R/W        | 0x0         | HS_TMR1_CUR_VALUE_LO<br>Bit[31:0] of the HSTimer1 current value |

### 3.8.6.12 0x0050 HS Timer1 Current Value Hi Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: HS_TMR1_CURNT_HI_REG                              |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:24          | /          | /           | /                                                                |
| 23:0           | R/W        | 0x0         | HS_TMR1_CUR_VALUE_HI<br>Bit[55:32] of the HSTimer1 current value |

**NOTE**

HSTimer1 is a 56-bit counter. The current value consists of two parts: HS\_TMR1\_CUR\_VALUE\_LO acts as the bit[31:0] and HS\_TMR1\_CUR\_VALUE\_HI acts as the bit[55:32]. To read or write the current value, HS\_TMR1\_CUR\_VALUE\_LO should be done before HS\_TMR1\_CUR\_VALUE\_HI.

## 3.9 Generic Interrupt Controller (GIC)

### 3.9.1 Overview

The GIC-400 is a high-performance, area-optimized interrupt controller with an Advanced Microcontroller Bus Architecture (AMBA) Advanced eXtensible Interface (AXI) interface. It detects, manages, and distributes interrupts in System on Chip (SoC) configurations. You can configure the GIC-400 to provide the optimum features, performance, and gate count required for your intended application.

For details about GIC, please refer to the [GIC PL400 technical reference](#) manual and [ARM GIC Architecture Specification V2.0](#).

### 3.9.2 Functional Description

The following table describes the details of interrupt sources.



#### CAUTION

The CPU interrupt seen by DSP is subtracted 32 from the following interrupt number. For example, the interrupt number of MSGBOX is 32, then the interrupt number seen by DSP is 0.

**Table 3-11 Interrupt Sources**

| Interrupt Number | Interrupt Source | Interrupt Vector | Description      |
|------------------|------------------|------------------|------------------|
| 0                | SGI 0            | 0x0000           | SGI 0 interrupt  |
| 1                | SGI 1            | 0x0004           | SGI 1 interrupt  |
| 2                | SGI 2            | 0x0008           | SGI 2 interrupt  |
| 3                | SGI 3            | 0x000C           | SGI 3 interrupt  |
| 4                | SGI 4            | 0x0010           | SGI 4 interrupt  |
| 5                | SGI 5            | 0x0014           | SGI 5 interrupt  |
| 6                | SGI 6            | 0x0018           | SGI 6 interrupt  |
| 7                | SGI 7            | 0x001C           | SGI 7 interrupt  |
| 8                | SGI 8            | 0x0020           | SGI 8 interrupt  |
| 9                | SGI 9            | 0x0024           | SGI 9 interrupt  |
| 10               | SGI 10           | 0x0028           | SGI 10 interrupt |
| 11               | SGI 11           | 0x002C           | SGI 11 interrupt |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description          |
|------------------|------------------|------------------|----------------------|
| 12               | SGI 12           | 0x0030           | SGI 12 interrupt     |
| 13               | SGI 13           | 0x0034           | SGI 13 interrupt     |
| 14               | SGI 14           | 0x0038           | SGI 14 interrupt     |
| 15               | SGI 15           | 0x003C           | SGI 15 interrupt     |
| 16               | PPI 0            | 0x0040           | PPI 0 interrupt      |
| 17               | PPI 1            | 0x0044           | PPI 1 interrupt      |
| 18               | PPI 2            | 0x0048           | PPI 2 interrupt      |
| 19               | PPI 3            | 0x004C           | PPI 3 interrupt      |
| 20               | PPI 4            | 0x0050           | PPI 4 interrupt      |
| 21               | PPI 5            | 0x0054           | PPI 5 interrupt      |
| 22               | PPI 6            | 0x0058           | PPI 6 interrupt      |
| 23               | PPI 7            | 0x005C           | PPI 7 interrupt      |
| 24               | PPI 8            | 0x0060           | PPI 8 interrupt      |
| 25               | PPI 9            | 0x0064           | PPI 9 interrupt      |
| 26               | PPI 10           | 0x0068           | PPI 10 interrupt     |
| 27               | PPI 11           | 0x006C           | PPI 11 interrupt     |
| 28               | PPI 12           | 0x0070           | PPI 12 interrupt     |
| 29               | PPI 13           | 0x0074           | PPI 13 interrupt     |
| 30               | PPI 14           | 0x0078           | PPI 14 interrupt     |
| 31               | PPI 15           | 0x007C           | PPI 15 interrupt     |
| 32               | CPUX_MSGBOX_R    | 0x0080           | CPUX MSGBOX READ IRQ |
| 33               |                  | 0x0084           |                      |
| 34               | UART0            | 0x0088           |                      |
| 35               | UART1            | 0x008C           |                      |
| 36               | UART2            | 0x0090           |                      |
| 37               | UART3            | 0x0094           |                      |
| 38               | UART4            | 0x0098           |                      |
| 39               | UART5            | 0x009C           |                      |
| 40               |                  | 0x00A0           |                      |
| 41               | TWI0             | 0x00A4           |                      |
| 42               | TWI1             | 0x00A8           |                      |
| 43               | TWI2             | 0x00AC           |                      |
| 44               | TWI3             | 0x00B0           |                      |
| 45               |                  | 0x00B4           |                      |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description      |
|------------------|------------------|------------------|------------------|
| 46               |                  | 0x00B8           |                  |
| 47               | SPI0             | 0x00BC           |                  |
| 48               | SPI1             | 0x00C0           |                  |
| 49               |                  | 0x00C4           |                  |
| 50               | PWM              | 0x00C8           |                  |
| 51               | CIR_TX           | 0x00CC           |                  |
| 52               | LEDC             | 0x00D0           |                  |
| 53               |                  | 0x00D4           |                  |
| 54               |                  | 0x00D8           |                  |
| 55               | OWA              | 0x00DC           |                  |
| 56               | DMIC             | 0x00E0           |                  |
| 57               | AUDIO_CODEC      | 0x00E4           |                  |
| 58               |                  | 0x00E8           |                  |
| 59               | I2S/PCM1         | 0x00EC           |                  |
| 60               | I2S/PCM2         | 0x00F0           |                  |
| 61               | USBO_DEVICE      | 0x00F4           |                  |
| 62               | USBO_EHCI        | 0x00F8           |                  |
| 63               | USBO_OHCI        | 0x00FC           |                  |
| 64               |                  | 0x0100           |                  |
| 65               | USB1_EHCI        | 0x0104           |                  |
| 66               | USB1_OHCI        | 0x0108           |                  |
| 67               |                  | 0x010C           |                  |
| 68               |                  | 0x0110           |                  |
| 69               |                  | 0x0114           |                  |
| 70               |                  | 0x0118           |                  |
| 71               |                  | 0x011C           |                  |
| 72               | SMHC0            | 0x0120           |                  |
| 73               | SMHC1            | 0x0124           |                  |
| 74               | SMHC2            | 0x0128           |                  |
| 75               | MSI              | 0x012C           |                  |
| 76               | SMC              | 0x0130           |                  |
| 77               |                  | 0x0134           |                  |
| 78               | EMAC             | 0x0138           |                  |
| 79               | TZMA_ERR         | 0x013C           | SRAM_A1 TZMA IRQ |

| Interrupt Number | Interrupt Source    | Interrupt Vector | Description                  |
|------------------|---------------------|------------------|------------------------------|
| 80               | CCU_FERR            | 0x0140           |                              |
| 81               | AHB_HREADY_TIME_OUT | 0x0144           | SYS_CTRL ahb_hready time out |
| 82               | DMA_CNS             | 0x0148           |                              |
| 83               | DMA_S               | 0x014C           |                              |
| 84               | CE_NS               | 0x0150           |                              |
| 85               | CE_S                | 0x0154           |                              |
| 86               | SPINLOCK            | 0x0158           |                              |
| 87               | HSTIMERO            | 0x015C           |                              |
| 88               | HSTIMER1            | 0x0160           |                              |
| 89               | GPADC               | 0x0164           |                              |
| 90               | THS                 | 0x0168           | Thermal Sensor IRQ           |
| 91               | TIMERO              | 0x016C           |                              |
| 92               | TIMER1              | 0x0170           |                              |
| 93               |                     | 0x0174           |                              |
| 94               | TPADC               | 0x0178           |                              |
| 95               | WATCHDOG            | 0x017C           |                              |
| 96               | IOMMU               | 0x0180           |                              |
| 97               |                     | 0x0184           |                              |
| 98               | VE                  | 0x0188           |                              |
| 99               |                     | 0x018C           |                              |
| 100              |                     | 0x0190           |                              |
| 101              | GPIOB_NS            | 0x0194           |                              |
| 102              | GPIOB_S             | 0x0198           |                              |
| 103              | GPIOC_NS            | 0x019C           |                              |
| 104              | GPIOC_S             | 0x01A0           |                              |
| 105              | GPIOD_NS            | 0x01A4           |                              |
| 106              | GPIOD_S             | 0x01A8           |                              |
| 107              | GPIOE_NS            | 0x01AC           |                              |
| 108              | GPIOE_S             | 0x01B0           |                              |
| 109              | GPIOF_NS            | 0x01B4           |                              |
| 110              | GPIOF_S             | 0x01B8           |                              |
| 111              | GPIOG_NS            | 0x01BC           |                              |
| 112              | GPIOG_S             | 0x01C0           |                              |

| Interrupt Number | Interrupt Source    | Interrupt Vector | Description                    |
|------------------|---------------------|------------------|--------------------------------|
| 113              |                     | 0x01C4           |                                |
| 114              |                     | 0x01C8           |                                |
| 115              |                     | 0x01CC           |                                |
| 116              |                     | 0x01D0           |                                |
| 117              | CPUX_MSGBOX_DSP_W   | 0x01D4           | CPUX_MSGBOX_WRITE IRQ for DSP  |
| 118              | CPUX_MSGBOX_RISCV_W | 0x01D8           | PUX_MSGBOX_WRITE IRQ FOR RISCV |
| 119              | DE                  | 0x01DC           |                                |
| 120              | DI                  | 0x01E0           |                                |
| 121              | G2D                 | 0x01E4           |                                |
| 122              | LCD                 | 0x01E8           |                                |
| 123              | TV                  | 0x01EC           |                                |
| 124              | DSI                 | 0x01F0           |                                |
| 125              |                     | 0x01F4           |                                |
| 126              | TVE                 | 0x01F8           | CVBS OUT interrupt             |
| 127              | CSI_DMA0            | 0x01FC           |                                |
| 128              | CSI_DMA1            | 0x0200           |                                |
| 129              |                     | 0x0204           |                                |
| 130              |                     | 0x0208           |                                |
| 131              |                     | 0x020C           |                                |
| 132              | CSI_PARSER0         | 0x0210           |                                |
| 133              |                     | 0x0214           |                                |
| 134              |                     | 0x0218           |                                |
| 135              |                     | 0x021C           |                                |
| 136              |                     | 0x0220           |                                |
| 137              |                     | 0x0224           |                                |
| 138              | CSI_TOP_PKT         | 0x0228           |                                |
| 139              | TVD                 | 0x022C           | CVBS IN interrupt              |
| 140              |                     | 0x0230           |                                |
| 141              |                     | 0x0234           |                                |
| 142              |                     | 0x0238           |                                |
| 143              |                     | 0x023C           |                                |
| 144              |                     | 0x0240           |                                |

| <b>Interrupt Number</b> | <b>Interrupt Source</b> | <b>Interrupt Vector</b> | <b>Description</b>                  |
|-------------------------|-------------------------|-------------------------|-------------------------------------|
| 145                     |                         | 0x0244                  |                                     |
| 146                     |                         | 0x0248                  |                                     |
| 147                     |                         | 0x024C                  |                                     |
| 148                     |                         | 0x0250                  |                                     |
| 149                     |                         | 0x0254                  |                                     |
| 150                     |                         | 0x0258                  |                                     |
| 151                     |                         | 0x025C                  |                                     |
| 152                     | DSP_DEE                 | 0x0260                  | DSP_SYS[0]:<br>DoubleExceptionError |
| 153                     | DSP_PFE                 | 0x0264                  | DSP_SYS[1]: PFatalError             |
| 154                     | DSP_WDG                 | 0x0268                  |                                     |
| 155                     | DSP_MBOX_CPUX_W         | 0x026C                  |                                     |
| 156                     | DSP_MBOX_RISCV_W        | 0x0270                  | DSP_SYS[4]                          |
| 157                     | DSP_TZMA                | 0x0274                  |                                     |
| 158                     |                         | 0x0278                  |                                     |
| 159                     |                         | 0x027C                  |                                     |
| 160                     | RISCV_MBOX_RISCV        | 0x0280                  | RISCV_MSGBOX_READ IRQ<br>FOR RISCV  |
| 161                     | RISCV_MBOX_DSP          | 0x0284                  | RISCV_MSGBOX_WRITE IRQ<br>FOR DSP   |
| 162                     | RISCV_MBOX_CPUX         | 0x0288                  | RISCV_MSGBOX_WRITE IRQ<br>FOR RISCV |
| 163                     | RISCV_WDG               | 0x028C                  |                                     |
| 164                     |                         | 0x0290                  |                                     |
| 165                     |                         | 0x0294                  |                                     |
| 166                     |                         | 0x0298                  |                                     |
| 167                     |                         | 0x029C                  |                                     |
| <b>CPUS Related</b>     |                         |                         |                                     |
| 168                     | NMI                     | 0x02A0                  |                                     |
| 169                     | PPU                     | 0x02A4                  |                                     |
| 170                     | TWD                     | 0x02A8                  |                                     |
| 171                     |                         | 0x02AC                  |                                     |
| 172                     | TIMER0                  | 0x02B0                  |                                     |
| 173                     | TIMER1                  | 0x02B4                  |                                     |
| 174                     | TIMER2                  | 0x02B8                  |                                     |

| <b>Interrupt Number</b> | <b>Interrupt Source</b> | <b>Interrupt Vector</b> | <b>Description</b>                            |
|-------------------------|-------------------------|-------------------------|-----------------------------------------------|
| 175                     | TIMER3                  | 0x02BC                  |                                               |
| 176                     | ALARM0                  | 0x02C0                  |                                               |
| 177                     |                         | 0x02C4                  |                                               |
| 178                     |                         | 0x02C8                  |                                               |
| 179                     |                         | 0x02CC                  |                                               |
| 180                     |                         | 0x02D0                  |                                               |
| 181                     |                         | 0x02D4                  |                                               |
| 182                     |                         | 0x02D8                  |                                               |
| 183                     | IRRX                    | 0x02DC                  | CPUS_IRRX_IRQ[9:0] OR to 1-bit in syscpus top |
| 184                     |                         | 0x02E0                  |                                               |
| 185                     |                         | 0x02E4                  |                                               |
| 186                     | AHBS_HREADY_TIME_OUT    | 0x02EC                  | CPUS AHB READY TIME OUT IRQ                   |
| 187                     |                         | 0x02F0                  |                                               |
| 188                     |                         | 0x02F4                  |                                               |
| 189                     |                         | 0x02F8                  |                                               |
| 190                     |                         | 0x02FC                  |                                               |
| 191                     |                         | 0x0300                  |                                               |
| <b>CPUX Related</b>     |                         |                         |                                               |
| 192                     | C0_CTL0                 | 0x0304                  | C0_CTL0 interrupt                             |
| 193                     | C0_CTL1                 | 0x0308                  | C0_CTL1 interrupt                             |
| 194                     |                         | 0x030C                  |                                               |
| 195                     |                         | 0x0310                  |                                               |
| 196                     | C0_COMMTX0              | 0x0314                  | C0_COMMTX0 interrupt                          |
| 197                     | C0_COMMTX1              | 0x0318                  | C0_COMMTX1 interrupt                          |
| 198                     |                         | 0x031C                  |                                               |
| 199                     |                         | 0x0320                  |                                               |
| 200                     | C0_COMMRX0              | 0x0324                  | C0_COMMRX0 interrupt                          |
| 201                     | C0_COMMRX1              | 0x0328                  | C0_COMMRX1 interrupt                          |
| 202                     |                         | 0x032C                  |                                               |
| 203                     |                         | 0x0330                  |                                               |
| 204                     | C0_PMU0                 | 0x0334                  | C0_PMU0 interrupt                             |
| 205                     | C0_PMU1                 | 0x0338                  | C0_PMU1 interrupt                             |

| Interrupt Number | Interrupt Source  | Interrupt Vector | Description            |
|------------------|-------------------|------------------|------------------------|
| 206              |                   | 0x033C           |                        |
| 207              |                   | 0x0340           |                        |
| 208              | C0_AXI_ERROR      | 0x0344           | C0_AXI_ERROR interrupt |
| 209              |                   | 0x0348           |                        |
| 210              | AXI_WR_IRQ        | 0x034C           |                        |
| 211              | AXI_RD_IRQ        | 0x0350           |                        |
| 212              | DBGWRUPREQ_out[0] | 0x0354           |                        |
| 213              | DBGWRUPREQ_out[1] | 0x0358           |                        |
| 214              |                   | 0x035C           |                        |
| 215              |                   | 0x0360           |                        |
| 216              |                   | 0x0364           |                        |
| 217              |                   | 0x0368           |                        |
| 218              |                   | 0x036C           |                        |
| 219              |                   | 0x0370           |                        |
| 220              |                   | 0x0374           |                        |
| 221              |                   | 0x0378           |                        |
| 222              |                   | 0x037C           |                        |
| 223              |                   | 0x0380           |                        |

## 3.10 Platform-Level Interrupt Controller (PLIC)

### 3.10.1 Overview

The PLIC is only used for sampling, priority arbitration and distribution for external interrupt sources.

- Sampling, priority arbitration and distribution for external interrupt sources
- The interrupt can be configured as machine mode and super user mode
- Up to 256 interrupt source sampling, supporting level interrupt and pulse interrupt
- 32 levels of interrupt priority
- Maintains independently the interrupt enable for each interrupt mode (machine/super user)
- Maintains independently the interrupt threshold for each interrupt mode (machine/super user)
- Configurable access permission for PLIC registers

### 3.10.2 Functional Description

The following table describes the details of interrupt sources.

Table 3-12 Interrupt Sources

| Interrupt Number | Interrupt Source | Interrupt Vector | Description |
|------------------|------------------|------------------|-------------|
| 0–15             | Reserved         | 0x0000–0x003C    | Not used    |
| 16               |                  | 0x0040           |             |
| 17               |                  | 0x0044           |             |
| 18               | UART0            | 0x0048           |             |
| 19               | UART1            | 0x004C           |             |
| 20               | UART2            | 0x0050           |             |
| 21               | UART3            | 0x0054           |             |
| 22               | UART4            | 0x0058           |             |
| 23               | UART5            | 0x005C           |             |
| 24               |                  | 0x0060           |             |
| 25               | TWI0             | 0x0064           |             |
| 26               | TWI1             | 0x0068           |             |
| 27               | TWI2             | 0x006C           |             |
| 28               | TWI3             | 0x0070           |             |
| 29               |                  | 0x0074           |             |

| Interrupt Number | Interrupt Source | Interrupt Vector | Description |
|------------------|------------------|------------------|-------------|
| 30               |                  | 0x0078           |             |
| 31               | SPI0             | 0x007C           |             |
| 32               | SPI1             | 0x0080           |             |
| 33               |                  | 0x0084           |             |
| 34               | PWM              | 0x0088           |             |
| 35               | IR_TX            | 0x008C           |             |
| 36               | LEDC             | 0x0090           |             |
| 37               |                  | 0x0094           |             |
| 38               |                  | 0x0098           |             |
| 39               | OWA              | 0x009C           |             |
| 40               | DMIC             | 0x00A0           |             |
| 41               | AUDIO_CODEC      | 0x00A4           |             |
| 42               | I2S/PCM0         | 0x00A8           |             |
| 43               | I2S/PCM1         | 0x00AC           |             |
| 44               | I2S/PCM2         | 0x00B0           |             |
| 45               | USBO_DEVICE      | 0x00B4           |             |
| 46               | USBO_EHCI        | 0x00B8           |             |
| 47               | USBO_OHCI        | 0x00BC           |             |
| 48               |                  | 0x00C0           |             |
| 49               | USB1_EHCI        | 0x00C4           |             |
| 50               | USB1_OHCI        | 0x00C8           |             |
| 51               |                  | 0x00CC           |             |
| 52               |                  | 0x00D0           |             |
| 53               |                  | 0x00D4           |             |
| 54               |                  | 0x00D8           |             |
| 55               |                  | 0x00DC           |             |
| 56               | SMHC0            | 0x00E0           |             |
| 57               | SMHC1            | 0x00E4           |             |
| 58               | SMHC2            | 0x00E8           |             |
| 59               | MSI              | 0x00EC           |             |
| 60               |                  | 0x00F0           |             |
| 61               |                  | 0x00F4           |             |
| 62               | EMAC             | 0x00F8           |             |
| 63               |                  | 0x00FC           |             |

| Interrupt Number | Interrupt Source    | Interrupt Vector | Description                  |
|------------------|---------------------|------------------|------------------------------|
| 64               | CCU_FERR            | 0x0100           |                              |
| 65               | AHB_HREADY_TIME_OUT | 0x0104           | SYS_CTRL ahb_hready time out |
| 66               | DMAC_NS             | 0x0108           |                              |
| 67               |                     | 0x010C           |                              |
| 68               | CE_NS               | 0x0110           |                              |
| 69               |                     | 0x0114           |                              |
| 70               | SPINLOCK            | 0x0118           |                              |
| 71               | HSTIMERO            | 0x011C           |                              |
| 72               | HSTIMER1            | 0x0120           |                              |
| 73               | GPADC               | 0x0124           |                              |
| 74               | THS                 | 0x0128           | Thermal Sensor IRQ           |
| 75               | TIMERO              | 0x012C           |                              |
| 76               | TIMER1              | 0x0130           |                              |
| 77               |                     | 0x0134           |                              |
| 78               | TPADC               | 0x0138           |                              |
| 79               | WATCHDOG            | 0x013C           |                              |
| 80               | IOMMU               | 0x0140           |                              |
| 81               |                     | 0x0144           |                              |
| 82               | VE                  | 0x0148           |                              |
| 83               |                     | 0x014C           |                              |
| 84               |                     | 0x0150           |                              |
| 85               | GPIOB_NS            | 0x0154           |                              |
| 86               |                     | 0x0158           |                              |
| 87               | GPIOC_NS            | 0x015C           |                              |
| 88               |                     | 0x0160           |                              |
| 89               | GPIOD_NS            | 0x0164           |                              |
| 90               |                     | 0x0168           |                              |
| 91               | GPIOE_NS            | 0x016C           |                              |
| 92               |                     | 0x0170           |                              |
| 93               | GPIOF_NS            | 0x0174           |                              |
| 94               |                     | 0x0178           |                              |
| 95               | GPIOG_NS            | 0x017C           |                              |
| 96               |                     | 0x0180           |                              |

| Interrupt Number | Interrupt Source    | Interrupt Vector | Description                     |
|------------------|---------------------|------------------|---------------------------------|
| 97               |                     | 0x0184           |                                 |
| 98               |                     | 0x0188           |                                 |
| 99               |                     | 0x018C           |                                 |
| 100              |                     | 0x0190           |                                 |
| 101              |                     | 0x0194           |                                 |
| 102              | CPUX_MSGBOX_RISCV_W | 0x0198           | CPUX_MSGBOX WRITE IRQ FOR RISCV |
| 103              | DE                  | 0x019C           |                                 |
| 104              | DI                  | 0x01A0           |                                 |
| 105              | G2D                 | 0x01A4           |                                 |
| 106              | LCD                 | 0x01A8           |                                 |
| 107              | TV                  | 0x01AC           |                                 |
| 108              | DSI                 | 0x01B0           |                                 |
| 109              |                     | 0x01B4           |                                 |
| 110              | TVE                 | 0x01B8           | CVBS OUT interrupt              |
| 111              | CSI_DMA0            | 0x01BC           |                                 |
| 112              | CSI_DMA1            | 0x01C0           |                                 |
| 113              |                     | 0x01C4           |                                 |
| 114              |                     | 0x01C8           |                                 |
| 115              |                     | 0x01CC           |                                 |
| 116              | CSI_PARSER0         | 0x01D0           |                                 |
| 117              |                     | 0x01D4           |                                 |
| 118              |                     | 0x01D8           |                                 |
| 119              |                     | 0x01DC           |                                 |
| 120              |                     | 0x01E0           |                                 |
| 121              |                     | 0x01E4           |                                 |
| 122              | CSI_TOP_PKT         | 0x01E8           |                                 |
| 123              | TVD                 | 0x01EC           | CVBS IN interrupt               |
| 124              |                     | 0x01F0           |                                 |
| 125              |                     | 0x01F4           |                                 |
| 126              |                     | 0x01F8           |                                 |
| 127              |                     | 0x01FC           |                                 |
| 128              |                     | 0x0200           |                                 |
| 129              |                     | 0x0204           |                                 |

| Interrupt Number | Interrupt Source   | Interrupt Vector | Description                          |
|------------------|--------------------|------------------|--------------------------------------|
| 130              |                    | 0x0208           |                                      |
| 131              |                    | 0x020C           |                                      |
| 132              |                    | 0x0210           |                                      |
| 133              |                    | 0x0214           |                                      |
| 134              |                    | 0x0218           |                                      |
| 135              |                    | 0x021C           |                                      |
| 136              | DSP_DEE            | 0x0220           | DSP_SYS[0]:<br>DoubleExceptionError  |
| 137              | DSP_PFE            | 0x0224           | DSP_SYS[1]: PFatalError              |
| 138              | DSP_WDG            | 0x0228           |                                      |
| 139              |                    | 0x022C           |                                      |
| 140              | DSP_MBOX_RISC-V_W  | 0x0230           |                                      |
| 141              | DSP_TZMA           | 0x0234           |                                      |
| 142              | DMAC_IRQ_DSP_NS    | 0x0238           | DMA 8–15 channel irq to DSP          |
| 143              |                    | 0x023C           |                                      |
| 144              | RISC-V_MBOX_RISC-V | 0x0240           | RISC-V MSGBOX READ IRQ<br>for RISC-V |
| 145              | RISC-V_MBOX_DSP    | 0x0244           | RISC-V MSGBOX WRITE IRQ<br>for DSP   |
| 146              |                    | 0x0248           |                                      |
| 147              | RISC-V_WDG         | 0x024C           |                                      |
| 148              |                    | 0x0250           |                                      |
| 149              |                    | 0x0254           |                                      |
| 150              |                    | 0x0258           |                                      |
| 151              |                    | 0x025C           |                                      |
| 152              |                    | 0x260            |                                      |
| 153              |                    | 0x264            |                                      |
| 154              |                    | 0x268            |                                      |
| 155              |                    | 0x26C            |                                      |
| 156              |                    | 0x270            |                                      |
| 157              |                    | 0x274            |                                      |
| 158              |                    | 0x278            |                                      |
| 159              |                    | 0x27C            |                                      |
| 160              |                    | 0x280            |                                      |

| Interrupt Number    | Interrupt Source | Interrupt Vector | Description            |
|---------------------|------------------|------------------|------------------------|
| 161                 |                  | 0x284            |                        |
| 162                 |                  | 0x288            |                        |
| 163                 |                  | 0x28C            |                        |
| 164                 |                  | 0x290            |                        |
| 165                 |                  | 0x294            |                        |
| 166                 |                  | 0x298            |                        |
| 167                 | IRRX             | 0x29C            |                        |
| 168                 |                  | 0x2A0            |                        |
| 169                 |                  | 0x2A4            |                        |
| 170                 |                  | 0x2A8            |                        |
| 171                 |                  | 0x2AC            |                        |
| 172                 |                  | 0x2B0            |                        |
| 173                 |                  | 0x2B4            |                        |
| 174                 |                  | 0x2B8            |                        |
| 175                 |                  | 0x2BC            |                        |
| <b>CPUX Related</b> |                  |                  |                        |
| 176                 | C0_CTL0          | 0x2C0            | C0_CTL0 interrupt      |
| 177                 | C0_CTL1          | 0x2C4            | C0_CTL1 interrupt      |
| 178                 |                  | 0x2C8            |                        |
| 179                 |                  | 0x2CC            |                        |
| 180                 | C0_COMMTX0       | 0x2D0            | C0_COMMTX0 interrupt   |
| 181                 | C0_COMMTX1       | 0x2D4            | C0_COMMTX1 interrupt   |
| 182                 |                  | 0x2D8            |                        |
| 183                 |                  | 0x2DC            |                        |
| 184                 | C0_COMMRX0       | 0x2E0            | C0_COMMRX0 interrupt   |
| 185                 | C0_COMMRX1       | 0x2E4            | C0_COMMRX1 interrupt   |
| 186                 |                  | 0x2EC            |                        |
| 187                 |                  | 0x2F0            |                        |
| 188                 | C0_PMU0          | 0x2F4            | C0_PMU0 interrupt      |
| 189                 | C0_PMU1          | 0x2F8            | C0_PMU1 interrupt      |
| 190                 |                  | 0x2FC            |                        |
| 191                 |                  | 0x300            |                        |
| 192                 | C0_AXI_ERROR     | 0x304            | C0_AXI_ERROR interrupt |
| 193                 |                  | 0x308            |                        |

| Interrupt Number | Interrupt Source  | Interrupt Vector | Description |
|------------------|-------------------|------------------|-------------|
| 194              | AXI_WR_IRQ        | 0x30C            |             |
| 195              | AXI_RD_IRQ        | 0x310            |             |
| 196              | DBGWRUPREQ_out[0] | 0x314            |             |
| 197              | DBGWRUPREQ_out[1] | 0x318            |             |
| 198              |                   | 0x31C            |             |
| 199              |                   | 0x320            |             |
| 200              |                   | 0x324            |             |
| 201              |                   | 0x328            |             |
| 202              |                   | 0x32C            |             |
| 203              |                   | 0x330            |             |
| 204              |                   | 0x334            |             |
| 205              |                   | 0x338            |             |
| 206              |                   | 0x33C            |             |
| 207              |                   | 0x340            |             |
| 208              |                   | 0x344            |             |
| 209              |                   | 0x348            |             |
| 210              |                   | 0x34C            |             |
| 211              |                   | 0x350            |             |
| 212              |                   | 0x354            |             |
| 213              |                   | 0x358            |             |
| 214              |                   | 0x35C            |             |
| 215              |                   | 0x360            |             |
| 216              |                   | 0x364            |             |
| 217              |                   | 0x368            |             |
| 218              |                   | 0x36C            |             |
| 219              |                   | 0x370            |             |
| 220              |                   | 0x374            |             |
| 221              |                   | 0x378            |             |
| 222              |                   | 0x37C            |             |
| 223              |                   | 0x380            |             |

### 3.10.3 Register List

| Module Name | Base Address |
|-------------|--------------|
| RISCV PLIC  | 0x10000000   |

| Register Name   | Offset                    | Description                                     |
|-----------------|---------------------------|-------------------------------------------------|
| PLIC_PRIO_REGn  | 0x0000+n*0x0004 (0<n<256) | PLIC Priority Register n                        |
| PLIC_IP_REGn    | 0x1000+n*0x0004 (0≤n<9)   | PLIC Interrupt Pending Register n               |
| PLIC_MIE_REGn   | 0x2000+n*0x0004 (0≤n<9)   | PLIC Machine Mode Interrupt Enable Register n   |
| PLIC_SIE_REGn   | 0x2080+n*0x0004 (0≤n<9)   | PLIC Superuser Mode Interrupt Enable Register n |
| PLIC_CTRL_REG   | 0x1FFFFC                  | PLIC Control Register                           |
| PLIC_MTH_REG    | 0x200000                  | PLIC Machine Threshold Register                 |
| PLIC_MCLAIM_REG | 0x200004                  | PLIC Machine Claim Register                     |
| PLIC_STH_REG    | 0x201000                  | PLIC Superuser Threshold Register               |
| PLIC_SCLAIM_REG | 0x201004                  | PLIC Superuser Claim Register                   |

### 3.10.4 Register Description

#### 3.10.4.1 0x0000+n\*0x0004 (0<n<256) PLIC Priority Register n (Default Value: 0x0000\_0000)

| Offset: 0x0000+n*0x0004 (0<n<256) |            |             | Register Name: PLIC_PRIO_REGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:1                              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0                                 | R/W        | 0x0         | <p>PLIC_PRIO<br/>PLIC Priority</p> <p>Support for 32 different levels of priority.</p> <p>Where, a priority sets to 0 indicates that the interrupt is invalid. Machine mode interrupts have unconditionally higher priority than super-user mode interrupts. When the interrupt target mode is the same, priority 1 is the lowest priority, priority 31 is the highest priority. When multiple interrupts of the same priority are waiting arbitration, the interrupt source ID is compared. The smaller ID has the higher priority.</p> |

**3.10.4.2 0x1000+n\*0x0004 (0≤n<9) PLIC Interrupt Pending Register n (Default Value: 0x0000\_0000)**

| Offset: 0x1000+n*0x0004 (0≤n<9) |            |             | Register Name: PLIC_IP_REGn        |
|---------------------------------|------------|-------------|------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                        |
| 31:0                            | R/W        | 0x0         | PLIC_IP<br>PLIC Interrupt Pending. |

**3.10.4.3 0x2000+n\*0x0004 (0≤n<9) PLIC Machine Mode Interrupt Enable Register n (Default Value: 0x0000\_0000)**

| Offset: 0x2000+n*0x0004 (0≤n<9) |            |             | Register Name: PLIC_MIE_REGn                    |
|---------------------------------|------------|-------------|-------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                     |
| 31:0                            | R/W        | 0x0         | PLIC_MIE<br>PLIC Machine Mode Interrupt Enable. |

**3.10.4.4 0x2080+n\*0x0004 PLIC Superuser Mode Interrupt Enable Register n (0≤n<9) (Default Value: 0x0000\_0000)**

| Offset: 0x2080+n*0x0004 (0≤n<9) |            |             | Register Name: PLIC_SIE_REGn                      |
|---------------------------------|------------|-------------|---------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                       |
| 31:0                            | R/W        | 0x0         | PLIC_SIE<br>PLIC Superuser Mode Interrupt Enable. |

**3.10.4.5 0x1FFFFC PLIC Control Register (Default Value: 0x0000\_0000)**

| Offset: 0x1FFFFC |            |             | Register Name: PLIC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:1             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0                | R/W        | 0x0         | PLIC_CTRL<br>PLIC Control<br>0: Only the machine mode can access to all registers in PLIC. The super-user mode can not access PLIC_CTRL, PLIC_PRIO, PLIC_IP, and PLIC_IE registers, only access the interrupt threshold register and the interrupt response/completion register. The normal-user mode can not access any registers in PLIC.<br>1: The machine mode can access to all registers in PLIC. The super-user mode can access all registers except PLL_CTRL in PLIC. The normal-user mode can not access any registers in PLIC. |

**3.10.4.6 0x200000 PLIC Machine Threshold Register (Default Value: 0x0000\_0000)**

| Offset: 0x200000 |            |             | Register Name: PLIC_MTH_REG |
|------------------|------------|-------------|-----------------------------|
| Bit              | Read/Write | Default/Hex | Description                 |
| 31:5             | /          | /           | /                           |

| Offset: 0x200000 |            |             | Register Name: PLIC_MTH_REG                                                                                                                                                                                      |
|------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 4:0              | R/W        | 0x0         | <p>PLIC_MTH</p> <p>PLIC Machine Threshold</p> <p>Indicate the interrupt threshold of the current interrupt mode.</p> <p>If the threshold is configured to 0, it indicates that all interrupts are permitted.</p> |

#### 3.10.4.7 0x200004 PLIC Machine Claim Register (Default Value: 0x0000\_0000)

| Offset: 0x200004 |            |             | Register Name: PLIC_MCLAIM_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:10            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9:0              | R/W        | 0x0         | <p>PLIC_MCLAIM</p> <p>PLIC Machine Claim</p> <p>Read register: Return the current stored ID value of the register. The read operation indicates that the interrupt of the corresponding ID starts to perform. The PLIC starts to process the interrupt response.</p> <p>Write register: Indicate that the interrupt of the corresponding ID is complete. The writing operation can not update the response/completion register. The PLIC starts to process the interrupt completion.</p> |

#### 3.10.4.8 0x201000 PLIC Superuser Threshold Register (Default Value: 0x0000\_0000)

| Offset: 0x201000 |            |             | Register Name: PLIC_STH_REG                                                                                                                                                                                          |
|------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
| 31:5             | /          | /           | /                                                                                                                                                                                                                    |
| 4:0              | R/W        | 0x0         | <p>PLIC_STH.</p> <p>PLIC Superuser Threshold.</p> <p>Indicate the interrupt threshold of the current interrupt mode.</p> <p>If the threshold is configured to 0, it indicates that all interrupts are permitted.</p> |

#### 3.10.4.9 0x201004 PLIC Superuser Claim Register (Default Value: 0x0000\_0000)

| Offset: 0x201004 |            |             | Register Name: PLIC_SCLAIM_REG |
|------------------|------------|-------------|--------------------------------|
| Bit              | Read/Write | Default/Hex | Description                    |
| 31:10            | /          | /           | /                              |

| Offset: 0x201004 |            |             | Register Name: PLIC_SCLAIM_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9:0              | R/W        | 0x0         | <p>PLIC_SCLAIM.</p> <p>PLIC Superuser Claim.</p> <p>Read register: Return the current stored ID value of the register.</p> <p>The read operation indicates that the interrupt of the corresponding ID starts to perform. The PLIC starts to process the interrupt response.</p> <p>Write register: Indicate that the interrupt of the corresponding ID is complete. The writing operation can not update the response/completion register. The PLIC starts to process the interrupt completion.</p> |

## 3.11 Direct Memory Access Controller (DMAC)

### 3.11.1 Overview

The direct memory access (DMA) is a method of transferring data between peripherals and memories (including the SRAM and DRAM) without using the CPU. It is an efficient way to offload data transfer duties from the CPU. Without DMA, the CPU has to control all the data transfers. While with DMA, the DMAC directly transfers data between a peripheral and a memory, between peripherals, or between memories.

The DMAC has the following features:

- Up to 16 DMA channels
- Provides 32 peripheral DMA requests for data reading and 32 peripheral DMA requests for data writing
- Supports transferring data with a linked list
- Supports programmable 8-bit, 16-bit, 32-bit, and 64-bit data width
- Supports programmable DMA burst length
- DRQ response includes the waiting mode and handshake mode
- DMA channel supports pause function
- Memory devices support non-aligned transform

### 3.11.2 Block Diagram

The following figure shows a block diagram of DMAC.

**Figure 3-20 DMAC Block Diagram**



DMAC contains the following sub-blocks:

**Table 3-13 DMAC Sub-blocks**

| Sub-block         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DMA_ARBITER       | Arbitrates the DMA read/write requests from all channels, and converts the requests to the read/write requests of ports.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DMA_CHANNELS      | DMA transfer engine. Each channel is independent. When the DMA requests from multiple peripherals are valid simultaneously, the channel with the highest priority starts data transfer first. The system uses the polling mechanism to decide the priorities of DMA channels. When DMA_ARBITER is idle, channel 0 has the highest priority, whereas channel 15 has the lowest priority. When DMA_ARBITER is busy processing the request from channel $n$ , channel $(n+1)$ has the highest priority. For $n=15$ , the channel $(n+1)$ should be channel 0. |
| DRQs              | DMA requests. Peripherals use the DMA request signals to request a data transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DMA_MPORT         | Receives the read/write requests from DMA_ARBITER, and converts the requests to the corresponding MBUS access requests. It is mainly used for accessing the DRAM.                                                                                                                                                                                                                                                                                                                                                                                          |
| DMA_HPORT         | The port for accessing the AHB Master. It is mainly used for accessing the SRAM and IO devices.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DMA_FIFO CTR      | Internal FIFO cell control module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| DMA_REG Interface | DMA_REG is the common register module that is mainly used to resolve AHB demands.                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| DMA_CLKGATE       | The control module for hardware auto clock gating.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

The DMAC integrates 16 independent DMA channels and each channel has an independent FIFO controller. When the DMA channel starts, the DMAC gets a DMA descriptor from the DMA\_DESC\_ADDR\_REG and uses it as the configuration information for the data transfer of the current DMA package. Then the DMAC can transfer data between the specified devices. After transferring a DMA package, the DMAC judges if the current channel transfer is finished via the linked address in the descriptor. If the linked address shows all the packages are transferred, the DMAC will end the chain transmission and close the channel.

### 3.11.3 Functional Description

#### 3.11.3.1 Clock

The DMAC is on MBUS. The clock of MBUS influences the transfer efficiency of the DMAC.

### 3.11.3.2 Typical Application

The following figure shows a typical application of the DMAC.

Figure 3-21 DMAC Typical Application Diagram



### 3.11.3.3 DRQ Port of Peripherals

The following table shows the source DRQ types and destination DRQ types of different ports.

Table 3-14 DMA DRQ Type

| Source DRQ Type |             | Destination DRQ Type |             |
|-----------------|-------------|----------------------|-------------|
| port0           | SRAM        | port0                | SRAM        |
| port1           | DRAM        | port1                | DRAM        |
| port2           |             | port2                | OWA-TX      |
| port3           |             | port3                |             |
| port4           | I2S/PCM1-RX | port4                | I2S/PCM1-TX |
| port5           | I2S/PCM2-RX | port5                | I2S/PCM2-TX |
| port6           |             | port6                |             |
| port7           | Audio_Codec | port7                | Audio_Codec |
| port8           | DMIC        | port8                |             |

| Source DRQ Type |          | Destination DRQ Type |          |
|-----------------|----------|----------------------|----------|
| port9           |          | port9                |          |
| port10          |          | port10               |          |
| port11          |          | port11               |          |
| port12          | GPADC    | port12               |          |
| port13          | TPADC    | port13               | IR-TX    |
| port14          | UART0-RX | port14               | UART0-TX |
| port15          | UART1-RX | port15               | UART1-TX |
| port16          | UART2-RX | port16               | UART2-TX |
| port17          | UART3-RX | port17               | UART3-TX |
| port18          | UART4-RX | port18               | UART4-TX |
| port19          | UART5-RX | port19               | UART5-TX |
| port20          |          | port20               |          |
| port21          |          | port21               |          |
| port22          | SPI0-RX  | port22               | SPI0-TX  |
| port23          | SPI1-RX  | port23               | SPI1-TX  |
| port24          |          | port24               |          |
| port25          |          | port25               |          |
| port26          |          | port26               |          |
| port27          |          | port27               |          |
| port28          |          | port28               |          |
| port29          |          | port29               |          |
| Port30          | USBO_EP1 | Port30               | USBO_EP1 |
| Port31          | USBO_EP2 | Port31               | USBO_EP2 |
| Port32          | USBO_EP3 | Port32               | USBO_EP3 |
| Port33          | USBO_EP4 | Port33               | USBO_EP4 |
| Port34          | USBO_EP5 | Port34               | USBO_EP5 |
| Port35          |          | Port35               |          |
| Port36          |          | Port36               |          |
| Port37          |          | Port37               |          |
| Port38          |          | Port38               |          |
| Port39          |          | Port39               |          |
| Port40          |          | Port40               |          |
| Port41          |          | Port41               |          |
| Port42          |          | Port42               | LEDC     |

| Source DRQ Type |      | Destination DRQ Type |      |
|-----------------|------|----------------------|------|
| Port43          | TWI0 | Port43               | TWI0 |
| Port44          | TWI1 | Port44               | TWI1 |
| Port45          | TWI2 | Port45               | TWI2 |
| Port46          | TWI3 | Port46               | TWI3 |
| Port47          |      | Port47               |      |
| Port48          |      | Port48               |      |
| Port49          |      | Port49               |      |
| Port50          |      | Port50               |      |
| Port51          |      | Port51               |      |
| Port52          |      | Port52               |      |
| Port53          |      | Port53               |      |

### 3.11.3.4 DMA Descriptor

The DMAC descriptor is the configuration information of DMA transfer that decides the DMA working mode. Each descriptor includes 6 words: Configuration, Source Address, Destination Address, Byte Counter, Parameter, and Link. The following figure shows the structure of the DMA descriptor.

Figure 3-22 DMA Descriptor



- **Configuration:** Configure the following information by DMA\_CFG\_REG.
  - DRQ type: DRQ type of the source and destination devices.
  - Address counting mode: For both the source and destination devices, there are two address counting modes: the IO mode and linear mode. The IO mode is for IO devices whose address is fixed during the data transfer and the linear mode is for the memory whose address is increasing during the data transfer.

- Transferred block length: The amount of data that non-memory peripherals can transfer in a valid DRQ. The block length supports 1 bit, 4 bits, 8 bits, and 16 bits.
- Transferred data width: The data width of operating the non-memory peripherals. The data width supports 8 bits, 16 bits, 32 bits, and 64 bits.



### NOTE

The configuration supports BMODE mode. The BMODE is used in the following scenario: the source is an IO device, and the destination is a memory device. Setting the BMODE mode can limit the amount of block data transferred in DMA block transmission to the amount of data transferred when the DRQ threshold of the source IO device is 1. For example,

- **Source Address:** Configure the address of the source device.
- **Destination Address:** Configure the address of the destination device.

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

Both the DMA source and destination addresses have 34 bits. In the descriptor, because there are only 32 bits in the **Source/Destination Address** field, another 2 bits are stored in the **Parameter** field.

The following table shows the details of the related fields in the descriptor.

**Table 3-15 Source/Destination Address Distribution**

| Descriptor Group    | Bit   | Description                                                                     |
|---------------------|-------|---------------------------------------------------------------------------------|
| Source Address      | 31:0  | DMA transfers the lower 32 bits of the 34-bit source address                    |
| Destination Address | 31:0  | DMA transfers the lower 32 bits of the 34-bit destination address               |
| Parameter           | 31:20 | Reserved                                                                        |
|                     | 19:18 | DMA transfers the higher 2 bits of the 34-bit destination address               |
|                     | 17:16 | DMA transfers the high 2 bits of the 34-bit source address                      |
|                     | 15:8  | Reserved                                                                        |
|                     | 7:0   | Wait Clock Cycles<br>Set the waiting time in DRQ mode                           |
| Link                | 31:2  | The address of the next group descriptor, the lower 30 bits of the word address |
|                     | 1:0   | The address of the next group descriptor, the higher 2 bits of the word address |

From the above table, you can get:

Real DMA source address (in byte mode) = {Parameter [17:16], Source Address [31:0]};

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

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

- Byte counter:** Configure the data amount of a package. The maximum value is  $(2^{25}-1)$  bytes. If the data amount of the package reaches the maximum value, even if DRQ is valid, the DMA will stop the current transfer.
- Parameter:** Configure the interval between the data block. The parameter is valid for non-memory peripherals. When DMA detects that the DRQ is high, the DMA transfers the data block and ignores the status changes of the DRQ until the data transfer finishes. After that, the DMA waits for certain clock cycles (WAIT\_CYC) and executes the next DRQ detection.
- Link:** If the value of the link is 0xFFFFF800, the current package is at the end of the linked list. The DMAC will stop the data transfer after transferring the package; otherwise, the value of the link is considered as the descriptor address of the next package.

Figure 3-23 DMA Chain Transfer



### 3.11.3.5 Interrupts

There are three kinds of DMA interrupts: the half package interrupt, package end interrupt, and queue end interrupt.

**Half package interrupt:** When enabled, the DMAC sends out a half package interrupt after transferring half of a package.

**Package end interrupt:** When enabled, the DMAC sends out a package end interrupt after transferring a complete package.

**Queue end interrupt:** When enabled, the DMAC sends out a queue end interrupt after transferring a complete queue.

Notice that when CPU does not respond to the interrupts timely, or two DMA interrupts are generated very closely, the later interrupt may override the former one. That is, from the perspective of the CPU, the DMAC has only a system interrupt source.



#### NOTE

The DMAC has 16 channels and 2 groups of interrupts. The channel [7:0] corresponds to one group of interrupt, the channel [15:8] corresponds to another group of interrupt. The DSP is fixed to use the interrupt of the channel [15:8].

### 3.11.3.6 Clock Gating

The DMA\_CLK\_GATE module is a hardware module for controlling the clock gating automatically. It provides clock sources for sub-modules in DMAC and the module local circuits.

The DMA\_CLK\_GATE module consists of two parts: the channel clock gate and the common clock gate.

**Channel clock gate:** Controls the DMA clock of the DMA channels. When the system accesses the register of the current DMA channel and the DMA channel is enabled, the channel clock gate automatically opens the DMA clock. With a 16-HCLK-cycle delay after the system finishes accessing the register or the DMA data transfer is completed, the channel clock gate automatically closes the DMA clock. Also, the clock for the related circuits, such as for the channel control and FIFO control modules, will be closed.

**Common clock gate:** Controls the clocks of the DMA common circuits. The common circuits include the common circuit of the FIFO control module, MPORT module, and MBUS. When all the DMA channels are enabled, the common clock gate automatically closes the clocks for the above circuits.

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

### 3.11.3.7 Transfer Mode

The peripherals initiate data transfer by transmitting DMA request signals to the DMAC. After receiving the request signal, the DMAC converts it to the internal DRQ signal and controls the DMA data transfer.

The DMAC supports two data transfer modes: the waiting mode and handshake mode.

### The principle of waiting mode

- When the DMAC detects a valid external request signal, the DMAC starts to operate the peripheral device. The internal DRQ always holds high before the transferred data amount reaches the transferred block length.
- When the transferred data amount reaches the transferred block length, the internal DRQ pulls low automatically.
- The internal DRQ holds low for certain clock cycles (WAIT\_CYC), and then the DMAC restarts to detect the external requests. If the external request signal is valid, then the next transfer starts.

### The principle of handshake mode

- When the DMAC detects a valid external request signal, the DMAC starts to operate the peripheral device. The internal DRQ always holds high before the transferred data amount reaches the transferred block length.
- When the transferred data amount reaches the transferred block length, the internal DRQ will be pulled down automatically. For the last data transfer of the block, the DMAC sends a DMA Last signal with the DMA commands to the peripheral device. The DMA Last signal will be packed as part of the DMA commands and transmitted on the bus. It is used to inform the peripheral device that it is the end of the data transfer for the current DRQ.
- When the peripheral device receives the DMA Last signal, it can judge that the data transfer for the current DRQ is finished. To continue the data transfer, it sends a DMA Active signal to the DMAC.



#### NOTE

One DMA Active signal will be converted to one DRQ signal in the DMA module. To generate multiple DRQs, the peripheral device needs to send out multiple DMA Active signals via the bus protocol.

- When the DMAC received the DMA Active signal, it sends back a DMA ACK signal to the peripheral device.
- When the peripheral device receives the DMA ACK signal, it waits for all the operations on the local device completed, and both the FIFO and DRQ status refreshed. Then it invalidates the DMA Active signal.
- When the DMAC detects the falling edge of the DMA Active signal, it invalidates the corresponding DMA ACK signal, and restarts to detect the external request signals. If a valid request signal is detected, the next data transfer starts.

The following figure shows the workflow of the handshake mode.

**Figure 3-24 Workflow of the DMAC Handshake Mode**

### 3.11.3.8 Address Auto-Alignment

For the non-IO devices whose start address is not 32-byte-aligned, the DMAC will adjust the address to 32-byte-aligned through the burst transfer within 32 bytes. Adjusting address to 32-byte-aligned improves the DRAM access efficiency.

The following example shows how the DMAC adjusts the address: when the peripheral device of a DMA channel is a non-IO device whose start address is 0x86 (not 32-byte-aligned), the DMAC firstly uses a 26-byte burst transfer to align the address to 0xA0 (32-byte-aligned), and then transfers data by 64-byte burst (the maximum transfer amount that MBUS allows).

The IO devices do not support address alignment, so the bit width of IO devices must match the address offset; otherwise, the DMAC will ignore the inconsistency and directly transmit data of the corresponding bit width to the address.

The address of the DMA descriptor does not support the address auto-alignment. Make sure the address is word-aligned; otherwise the DMAC cannot identify the descriptor.

### 3.11.3.9 DMAC Clock Control

- The DMAC clock is synchronous with the AHB0 clock. Make sure that the DMAC gating bit of AHB0 clock is enabled before accessing the DMAC register.
- The reset input signal of the DMAC is asynchronous with AHB0 and is low valid by default. Make sure that the reset signal of the DMAC is de-asserted before accessing the DMA register.
- To avoid the indefinite state within registers, de-assert the reset signal first, and then open the gating bit of AHB0.
- The DMAC supports Clock Auto Gating function to reduce power consumption, the system will automatically disable the DMAC clock in the DMAC idle state. Clock Auto Gating is enabled by default.

## 3.11.4 Programming Guidelines

### 3.11.4.1 Using DMAC Transfer Process

The DMAC transfer process is as follows.

**Step 1** Request DMA channel, and check if the DMA channel is idle by checking if it is enabled. A disabled channel indicates it is idle, while an enabled channel indicates it is busy.

**Step 2** Write the descriptor with 6 words into the memory. The descriptor must be word-aligned. For more details, refer to section 3.11.3.4 “[DMA Descriptor](#)”.

**Step 3** Write the start address of the descriptor to [DMA DESC ADDR REGN](#).

**Step 4** Enable the DMA channel, and write the corresponding channel to [DMAC EN REGN](#).

**Step 5** The DMA obtains the descriptor information.

**Step 6** Start to transmit a package. When half of the package is completed, the DMA sends a Half Package Transfer Interrupt; when a total package is completed, the DMA sends a Package End Transfer Interrupt. These interrupt status can be read by [DMAC IRQ PEND REGO](#).

**Step 7** Set [DMAC PAU REGN](#) to pause or resume the data transfer.

**Step 8** After completing a total package transfer, the DMA decides to start the next package transfer or end the transfer by the link of the descriptor. If the link is 0xFFFFF800, the transfer ends; otherwise, the next package starts to transmit. When the transfer ends, the DMA sends a Queue End Transfer Interrupt.

**Step 9** Disable the DMA channel.

Figure 3-25 DMAC Transfer Process



### 3.11.4.2 Processing DMAC Interrupt

Follow the steps below to process the DMAC interrupt:

**Step 1** Enable interrupt: write the corresponding interrupt enable bit of [DMAC IRQ\\_EN REG0](#). The system generates an interrupt when the corresponding condition is satisfied.

**Step 2** After entering the interrupt process, write [C:\Users\zengjing\Downloads\ Hlk52357013 - Hlk52357103](#) to clear the interrupt pending and execute the process of waiting for the interrupt.

**Step 3** Resume the interrupt and continue to execute the interrupted process.

### 3.11.4.3 Configuring DMAC

To configure the DMAC, follow the guidelines below:

- Make sure the transfer bit width of IO devices is consistent with the offset of the start address.
- The MBUS protocol does not support the read operation of non-integer words. For the devices whose bit width is not word-aligned, after receiving the read command, they should resolve the read command according to their FIFO bit width instead of the command bit width, and ignore the redundant data caused by the inconsistency of the bit width.
- When the DMA transfer is paused, this is equivalent to invalid DRQ. Because there is a certain time delay between DMA transfer commands, the DMAC will not stop data transfer until the DMAC finishes processing the current command and the commands in Arbiter (at most 32 bytes data).

DMAC application example:

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

The DMAC supports increasing data package in transfer, pay attention to the following points:

- The 0xFFFFF800 value of **DMAC\_FDESC\_ADDR\_REGN** indicates that the DMA channel has got back the descriptor of the last package. The DMA channel will automatically stop the data transfer after transferring the current package.
- To add a package during the data transfer, check if the DMA channel has got back the descriptor of the last package. If yes, you cannot add any package in the current queue. Request another DMA channel with

a new DRQ to transfer the package. Otherwise, you can add the package by modifying the **DMAC\_FDESC\_ADDR\_REGN** of the last package from 0xFFFFF800 to the start address of the to-be-added package.

To ensure that the modification is valid, read the value of **DMAC\_FDESC\_ADDR\_REGN** after the modification. The value 0xFFFFF800 indicates the modification fails and the other values indicate you have successfully added packages to the queue.

Another problem is, the system needs some time to process the modification, during which the DMA channel may get back the descriptor of the last package. You can read **DMAC\_CUR\_SRC\_REGN** and **DMAC\_CUR\_DEST\_REGN** and check if the increasing memory address accords with the information of the added package. If yes, the package is added successfully; otherwise, the modification failed.

To ensure a higher rate of success, it is suggested that you add the package before the half package interrupt of the penultimate package.

### 3.11.5 Register List

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

| Register Name       | Offset            | Description                                               |
|---------------------|-------------------|-----------------------------------------------------------|
| DMAC IRQ_EN_REG0    | 0x0000            | DMAC IRQ Enable Register 0                                |
| DMAC IRQ_EN_REG1    | 0x0004            | DMAC IRQ Enable Register 1                                |
| DMAC IRQ_PEND_REG0  | 0x0010            | DMAC IRQ Pending Register 0                               |
| DMAC IRQ_PEND_REG1  | 0x0014            | DMAC IRQ Pending Register 1                               |
| DMAC_AUTO_GATE_REG  | 0x0028            | DMAC Auto Gating Register                                 |
| DMAC_STA_REG        | 0x0030            | DMAC Status Register                                      |
| DMAC_EN_REGN        | 0x0100 + N*0x0040 | DMAC Channel Enable Register N (N = 0 to 15)              |
| DMAC_PAU_REGN       | 0x0104 + N*0x0040 | DMAC Channel Pause Register N (N = 0 to 15)               |
| DMAC_DESC_ADDR_REGN | 0x0108 + N*0x0040 | DMAC Channel Start Address Register N (N = 0 to 15)       |
| DMAC_CFG_REGN       | 0x010C + N*0x0040 | DMAC Channel Configuration Register N (N = 0 to 15)       |
| DMAC_CUR_SRC_REGN   | 0x0110 + N*0x0040 | DMAC Channel Current Source Register N (N = 0 to 15)      |
| DMAC_CUR_DEST_REGN  | 0x0114 + N*0x0040 | DMAC Channel Current Destination Register N (N = 0 to 15) |
| DMAC_BCNT_LEFT_REGN | 0x0118 + N*0x0040 | DMAC Channel Byte Counter Left Register N (N = 0 to 15)   |
| DMAC_PARA_REGN      | 0x011C + N*0x0040 | DMAC Channel Parameter Register N (N = 0 to 15)           |

| Register Name        | Offset            | Description                                             |
|----------------------|-------------------|---------------------------------------------------------|
| DMAC_MODE_REGN       | 0x0128 + N*0x0040 | DMAC Mode Register N (N = 0 to 15)                      |
| DMAC_FDESC_ADDR_REGN | 0x012C + N*0x0040 | DMAC Former Descriptor Address Register N (N = 0 to 15) |
| DMAC_PKG_NUM_REGN    | 0x0130 + N*0x0040 | DMAC Package Number Register N (N = 0 to 15)            |

### 3.11.6 Register Description

#### 3.11.6.1 0x0000 DMAC IRQ Enable Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31             | /          | /           | /                                                                                                   |
| 30             | R/W        | 0x0         | DMA7_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 7<br>0: Disabled<br>1: Enabled   |
| 29             | R/W        | 0x0         | DMA7_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 7<br>0: Disabled<br>1: Enabled   |
| 28             | R/W        | 0x0         | DMA7_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 7<br>0: Disabled<br>1: Enabled |
| 27             | /          | /           | /                                                                                                   |
| 26             | R/W        | 0x0         | DMA6_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 6<br>0: Disabled<br>1: Enabled   |
| 25             | R/W        | 0x0         | DMA6_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 6<br>0: Disabled<br>1: Enabled   |

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 24             | R/W        | 0x0         | DMA6_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 6<br>0: Disabled<br>1: Enabled |
| 23             | /          | /           | /                                                                                                   |
| 22             | R/W        | 0x0         | DMA5_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 5<br>0: Disabled<br>1: Enabled   |
| 21             | R/W        | 0x0         | DMA5_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 5<br>0: Disabled<br>1: Enabled   |
| 20             | R/W        | 0x0         | DMA5_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 5<br>0: Disabled<br>1: Enabled |
| 19             | /          | /           | /                                                                                                   |
| 18             | R/W        | 0x0         | DMA4_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 4<br>0: Disabled<br>1: Enabled   |
| 17             | R/W        | 0x0         | DMA4_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 4<br>0: Disabled<br>1: Enabled   |
| 16             | R/W        | 0x0         | DMA4_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 4<br>0: Disabled<br>1: Enabled |
| 15             | /          | /           | /                                                                                                   |
| 14             | R/W        | 0x0         | DMA3_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 3<br>0: Disabled<br>1: Enabled   |

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 13             | R/W        | 0x0         | DMA3_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 3<br>0: Disabled<br>1: Enabled   |
| 12             | R/W        | 0x0         | DMA3_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 3<br>0: Disabled<br>1: Enabled |
| 11             | /          | /           | /                                                                                                   |
| 10             | R/W        | 0x0         | DMA2_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 2<br>0: Disabled<br>1: Enabled   |
| 9              | R/W        | 0x0         | DMA2_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 2<br>0: Disabled<br>1: Enabled   |
| 8              | R/W        | 0x0         | DMA2_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 2<br>0: Disabled<br>1: Enabled |
| 7              | /          | /           | /                                                                                                   |
| 6              | R/W        | 0x0         | DMA1_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 1<br>0: Disabled<br>1: Enabled   |
| 5              | R/W        | 0x0         | DMA1_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 1<br>0: Disabled<br>1: Enabled   |
| 4              | R/W        | 0x0         | DMA1_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 1<br>0: Disabled<br>1: Enabled |
| 3              | /          | /           | /                                                                                                   |

| Offset: 0x0000 |            |             | Register Name: DMAC_IRQ_EN_REG0                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 2              | R/W        | 0x0         | DMA0_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 0<br>0: Disabled<br>1: Enabled   |
| 1              | R/W        | 0x0         | DMA0_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 0<br>0: Disabled<br>1: Enabled   |
| 0              | R/W        | 0x0         | DMA0_HLAF_IRQ_EN<br>Enable the half package interrupt of DMA channel 0<br>0: Disabled<br>1: Enabled |

### 3.11.6.2 0x0004 DMAC IRQ Enable Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31             | /          | /           | /                                                                                                     |
| 30             | R/W        | 0x0         | DMA15_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 15<br>0: Disabled<br>1: Enabled   |
| 29             | R/W        | 0x0         | DMA15_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 15<br>0: Disabled<br>1: Enabled   |
| 28             | R/W        | 0x0         | DMA15_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 15<br>0: Disabled<br>1: Enabled |
| 27             | /          | /           | /                                                                                                     |
| 26             | R/W        | 0x0         | DMA14_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 14<br>0: Disabled<br>1: Enabled   |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 25             | R/W        | 0x0         | DMA14_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 14<br>0: Disabled<br>1: Enabled   |
| 24             | R/W        | 0x0         | DMA14_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 14<br>0: Disabled<br>1: Enabled |
| 23             | /          | /           | /                                                                                                     |
| 22             | R/W        | 0x0         | DMA13_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 13<br>0: Disabled<br>1: Enabled   |
| 21             | R/W        | 0x0         | DMA13_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 13<br>0: Disabled<br>1: Enabled   |
| 20             | R/W        | 0x0         | DMA13_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 13<br>0: Disabled<br>1: Enabled |
| 19             | /          | /           | /                                                                                                     |
| 18             | R/W        | 0x0         | DMA12_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 12<br>0: Disabled<br>1: Enabled   |
| 17             | R/W        | 0x0         | DMA12_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 12<br>0: Disabled<br>1: Enabled   |
| 16             | R/W        | 0x0         | DMA12_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 12<br>0: Disabled<br>1: Enabled |
| 15             | /          | /           | /                                                                                                     |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 14             | R/W        | 0x0         | DMA11_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 11<br>0: Disabled<br>1: Enabled   |
| 13             | R/W        | 0x0         | DMA11_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 11<br>0: Disabled<br>1: Enabled   |
| 12             | R/W        | 0x0         | DMA11_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 11<br>0: Disabled<br>1: Enabled |
| 11             | /          | /           | /                                                                                                     |
| 10             | R/W        | 0x0         | DMA10_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 10<br>0: Disabled<br>1: Enabled   |
| 9              | R/W        | 0x0         | DMA10_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 10<br>0: Disabled<br>1: Enabled   |
| 8              | R/W        | 0x0         | DMA10_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 10<br>0: Disabled<br>1: Enabled |
| 7              | /          | /           | /                                                                                                     |
| 6              | R/W        | 0x0         | DMA9_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 9<br>0: Disabled<br>1: Enabled     |
| 5              | R/W        | 0x0         | DMA9_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 9<br>0: Disabled<br>1: Enabled     |

| Offset: 0x0004 |            |             | Register Name: DMAC_IRQ_EN_REG1                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 4              | R/W        | 0x0         | DMA9_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 9<br>0: Disabled<br>1: Enabled |
| 3              | /          | /           | /                                                                                                   |
| 2              | R/W        | 0x0         | DMA8_QUEUE_IRQ_EN<br>Enable the queue end interrupt of DMA channel 8<br>0: Disabled<br>1: Enabled   |
| 1              | R/W        | 0x0         | DMA8_PKG_IRQ_EN<br>Enable the package end interrupt of DMA channel 8<br>0: Disabled<br>1: Enabled   |
| 0              | R/W        | 0x0         | DMA8_HALF_IRQ_EN<br>Enable the half package interrupt of DMA channel 8<br>0: Disabled<br>1: Enabled |

### 3.11.6.3 0x0010 DMAC IRQ Pending Status Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DMAC_IRQ_PEND_REG0                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31             | /          | /           | /                                                                                                                                                               |
| 30             | R/W1C      | 0x0         | DMA7_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 7. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 29             | R/W1C      | 0x0         | DMA7_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 7. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 28             | R/W1C      | 0x0         | DMA7_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 7. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 27             | /          | /           | /                                                                                                                                                                 |
| 26             | R/W1C      | 0x0         | DMA6_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 6. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 25             | R/W1C      | 0x0         | DMA6_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 6. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 24             | R/W1C      | 0x0         | DMA6_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 6. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 23             | /          | /           | /                                                                                                                                                                 |
| 22             | R/W1C      | 0x0         | DMA5_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 5. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 21             | R/W1C      | 0x0         | DMA5_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 5. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 20             | R/W1C      | 0x0         | DMA5_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 5. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 19             | /          | /           | /                                                                                                                                                                 |
| 18             | R/W1C      | 0x0         | DMA4_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 4. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 17             | R/W1C      | 0x0         | DMA4_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 4. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 16             | R/W1C      | 0x0         | DMA4_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 4. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 15             | /          | /           | /                                                                                                                                                                 |
| 14             | R/W1C      | 0x0         | DMA3_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 3. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 13             | R/W1C      | 0x0         | DMA3_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 3. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 12             | R/W1C      | 0x0         | DMA3_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 3. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 11             | /          | /           | /                                                                                                                                                                 |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 10             | R/W1C      | 0x0         | DMA2_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 2. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 9              | R/W1C      | 0x0         | DMA2_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 2. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 8              | R/W1C      | 0x0         | DMA2_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 2. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 7              | /          | /           | /                                                                                                                                                                 |
| 6              | R/W1C      | 0x0         | DMA1_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 1. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 5              | R/W1C      | 0x0         | DMA1_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 1. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 4              | R/W1C      | 0x0         | DMA1_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 1. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 3              | /          | /           | /                                                                                                                                                                 |
| 2              | R/W1C      | 0x0         | DMA0_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 0. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 1              | R/W1C      | 0x0         | <p>DMA0_PKG_IRQ_PEND<br/>The IRQ pending bit for the package end interrupt of the DMA channel 0. Write 1 to clear the pending status.</p> <p>0: No effect<br/>1: Pending</p>   |
| 0              | R/W1C      | 0x0         | <p>DMA0_HALF_IRQ_PEND<br/>The IRQ pending bit for the half package interrupt of the DMA channel 0. Write 1 to clear the pending status.</p> <p>0: No effect<br/>1: Pending</p> |

#### 3.11.6.4 0x0014 DMAC IRQ Pending Status Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31             | /          | /           | /                                                                                                                                                                                |
| 30             | R/W1C      | 0x0         | <p>DMA15_QUEUE_IRQ_PEND<br/>The IRQ pending bit for the queue end interrupt of the DMA channel 15. Write 1 to clear the pending status.</p> <p>0: No effect<br/>1: Pending</p>   |
| 29             | R/W1C      | 0x0         | <p>DMA15_PKG_IRQ_PEND<br/>The IRQ pending bit for the package end interrupt of the DMA channel 15. Write 1 to clear the pending status.</p> <p>0: No effect<br/>1: Pending</p>   |
| 28             | R/W1C      | 0x0         | <p>DMA15_HALF_IRQ_PEND<br/>The IRQ pending bit for the half package interrupt of the DMA channel 15. Write 1 to clear the pending status.</p> <p>0: No effect<br/>1: Pending</p> |
| 27             | /          | /           | /                                                                                                                                                                                |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                         |
| 26             | R/W1C      | 0x0         | DMA14_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 14. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 25             | R/W1C      | 0x0         | DMA14_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 14. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 24             | R/W1C      | 0x0         | DMA14_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 14. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 23             | /          | /           | /                                                                                                                                                                   |
| 22             | R/W1C      | 0x0         | DMA13_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 13. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 21             | R/W1C      | 0x0         | DMA13_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 13. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending.  |
| 20             | R/W1C      | 0x0         | DMA13_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 13. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 19             | /          | /           | /                                                                                                                                                                   |
| 18             | R/W1C      | 0x0         | DMA12_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 12. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                         |
| 17             | R/W1C      | 0x0         | DMA12_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 12. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 16             | R/W1C      | 0x0         | DMA12_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 12. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 15             | /          | /           | /                                                                                                                                                                   |
| 14             | R/W1C      | 0x0         | DMA11_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 11. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 13             | R/W1C      | 0x0         | DMA11_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 11. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 12             | R/W1C      | 0x0         | DMA11_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 11. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 11             | /          | /           | /                                                                                                                                                                   |
| 10             | R/W1C      | 0x0         | DMA10_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 10. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 9              | R/W1C      | 0x0         | DMA10_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 10. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |

| Offset: 0x0010 |            |             | Register Name: DMAC IRQ_PEND_REG0                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                         |
| 8              | R/W1C      | 0x0         | DMA10_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 10. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |
| 7              | /          | /           | /                                                                                                                                                                   |
| 6              | R/W1C      | 0x0         | DMA9_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 9. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending     |
| 5              | R/W1C      | 0x0         | DMA9_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 9. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending     |
| 4              | R/W1C      | 0x0         | DMA9_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 9. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |
| 3              | /          | /           | /                                                                                                                                                                   |
| 2              | R/W1C      | 0x0         | DMA8_QUEUE_IRQ_PEND<br>The IRQ pending bit for the queue end interrupt of the DMA channel 8. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending     |
| 1              | R/W1C      | 0x0         | DMA8_PKG_IRQ_PEND<br>The IRQ pending bit for the package end interrupt of the DMA channel 8. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending     |
| 0              | R/W1C      | 0x0         | DMA8_HALF_IRQ_PEND<br>The IRQ pending bit for the half package interrupt of the DMA channel 8. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending   |

### 3.11.6.5 0x0028 DMAC Auto Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: DMAC_AUTO_GATE_REG                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:3           | /          | /           | /                                                                                                                      |
| 2              | R/W        | 0x0         | DMA_MCLK_CIRCUIT<br>Auto gating bit of DMA_MCLK interface circuit<br>0: Auto gating enabled<br>1: Auto gating disabled |
| 1              | R/W        | 0x0         | DMA_COMMON_CIRCUIT<br>Auto gating bit of DMA common circuit<br>0: Auto gating enabled<br>1: Auto gating disabled       |
| 0              | R/W        | 0x0         | DMA_CHAN_CIRCUIT<br>Auto gating bit of DMA channel circuit<br>0: Auto gating enabled<br>1: Auto gating disabled        |



When initializing the DMA Controller, the bit[2] should be set up.

### 3.11.6.6 0x0030 DMAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: DMAC_STA_REG                  |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31             | R          | 0x0         | MBUS FIFO Status<br>0: Empty<br>1: Not Empty |
| 30:16          | /          | /           | /                                            |

| Offset: 0x0030 |            |             | Register Name: DMAC_STA_REG                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 15:0           | R          | 0x0         | <p>DMA_STATUS</p> <p>DMA Channel[15:0] Status</p> <p>The meaning of each bit:</p> <p>0: Idle</p> <p>1: Busy</p> |

### 3.11.6.7 0x0100 + N\*0x0040 DMAC Channel Enable Register N (Default Value: 0x0000\_0000)

| Offset: 0x0100 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_EN_REGN                                                  |
|--------------------------------------------|------------|-------------|------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                  |
| 31:1                                       | /          | /           | /                                                                            |
| 0                                          | R/W        | 0x0         | <p>DMA_EN</p> <p>DMA Channel Enable</p> <p>0: Disabled</p> <p>1: Enabled</p> |

### 3.11.6.8 0x0104 + N\*0x0040 DMAC Channel Pause Register N (Default Value: 0x0000\_0000)

| Offset: 0x0104 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_PAU_REGN                                                                                           |
|--------------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                                            |
| 31:1                                       | /          | /           | /                                                                                                                      |
| 0                                          | R/W        | 0x0         | <p>DMA_PAUSE</p> <p>Pause the DMA Channel Transfer Data</p> <p>0: Resume Transferring</p> <p>1: Pause Transferring</p> |

### 3.11.6.9 0x0108 + N\*0x0040 DMAC Channel Descriptor Address Register N (Default Value: 0x0000\_0000)

| Offset: 0x0108 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_DESC_ADDR_REGN                                                                                                                                             |
|--------------------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:2                                       | R/W        | 0x0         | DMA_DESC_ADDR<br>Lower 30 bits of DMA channel descriptor address<br>The descriptor address must be word-aligned.                                                               |
| 1:0                                        | R/W        | 0x0         | DMA_DESC_HIGH_ADDR<br>Higher 2 bits of DMA channel descriptor high address<br>The real address is as follows.<br>DMA Channel Descriptor Address = {bit[1:0], bit[31:2], 2'b00} |

### 3.11.6.10 0x010C + N\*0x0040 DMAC Channel Configuration Register N (Default Value: 0x0000\_0000)

| Offset: 0x010C + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_CFG_REGN                                                                             |
|--------------------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                              |
| 31                                         | /          | /           | /                                                                                                        |
| 30                                         | R          | 0x0         | BMODE_SEL<br>0: Normal Mode<br>1: BMODE                                                                  |
| 29:27                                      | /          | /           | /                                                                                                        |
| 26:25                                      | R          | 0x0         | DMA_DEST_DATA_WIDTH<br>DMA Destination Data Width<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: 64-bit |
| 24                                         | R          | 0x0         | DMA_ADDR_MODE<br>DMA Destination Address Mode<br>0: Linear Mode<br>1: IO Mode                            |

| Offset: 0x010C + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_CFG_REGN                                                                              |
|--------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                               |
| 23:22                                      | R          | 0x0         | DMA_DEST_BLOCK_SIZE<br>DMA Destination Block Size<br>00: 1<br>01: 4<br>10: 8<br>11: 16                    |
| 21:16                                      | R          | 0x0         | DMA_DEST_DRQ_TYPE<br>DMA Destination DRQ Type<br>The details in DRQ Type and Port Corresponding Relation. |
| 15:11                                      | /          | /           | /                                                                                                         |
| 10:9                                       | R          | 0x0         | DMA_SRC_DATA_WIDTH<br>DMA Source Data Width<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: 64-bit        |
| 8                                          | R          | 0x0         | DMA_SRC_ADDR_MODE<br>DMA Source Address Mode<br>0: Linear Mode<br>1: IO Mode                              |
| 7:6                                        | R          | 0x0         | DMA_SRC_BLOCK_SIZE<br>DMA Source Block Size<br>00: 1<br>01: 4<br>10: 8<br>11: 16                          |
| 5:0                                        | R          | 0x0         | DMA_SRC_DRQ_TYPE<br>DMA Source DRQ Type<br>The details in DRQ Type and Port Corresponding Relation.       |

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

| Offset: 0x0110 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_CUR_SRC_REGN                   |
|--------------------------------------------|------------|-------------|----------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                        |
| 31:0                                       | R          | 0x0         | DMA_CUR_SRC<br>DMA Channel Current Source Address. |

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

| Offset: 0x0114 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_CUR_DEST_REGN                        |
|--------------------------------------------|------------|-------------|----------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                              |
| 31:0                                       | R          | 0x0         | DMA_CUR_DEST<br>DMA Channel Current Destination Address. |

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

| Offset: 0x0118 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_BCNT_LEFT_REGN              |
|--------------------------------------------|------------|-------------|-------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                     |
| 31:25                                      | /          | /           | /                                               |
| 24:0                                       | R          | 0x0         | DMA_BCNT_LEFT<br>DMA Channel Byte Counter Left. |

### 3.11.6.14 0x011C + N\*0x0040 DMAC Channel Parameter Register N (Default Value: 0x0000\_0000)

| Offset: 0x011C + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC PARA REGN |
|--------------------------------------------|------------|-------------|-------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                   |
| 31:8                                       | /          | /           | /                             |
| 7:0                                        | R          | 0x0         | WAIT_CYC<br>Wait Clock Cycles |

### 3.11.6.15 0x0128 + N\*0x0040 DMAC Mode Register N (Default Value: 0x0000\_0000)

| Offset: 0x0128 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_MODE_REGN                                                                 |
|--------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                   |
| 31:4                                       | /          | /           | /                                                                                             |
| 3                                          | R/W        | 0x0         | DMA_DST_MODE<br>Destination Communication Mode Select<br>0: Waiting mode<br>1: Handshake mode |
| 2                                          | R/W        | 0x0         | DMA_SRC_MODE<br>Source Communication Mode Select<br>0: Waiting mode<br>1: Handshake mode      |
| 1:0                                        | /          | /           | /                                                                                             |

### 3.11.6.16 0x012C + N\*0x0040 DMAC Former Descriptor Address Register N (Default Value: 0x0000\_0000)

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

### 3.11.6.17 0x0130 + N\*0x0040 DMAC Package Number Register N (Default Value: 0x0000\_0000)

| Offset: 0x0130 + N*0x0040<br>(N = 0 to 15) |            |             | Register Name: DMAC_PKG_NUM_REGN                                                                          |
|--------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit                                        | Read/Write | Default/Hex | Description                                                                                               |
| 31:0                                       | R          | 0x0         | DMA_PKG_NUM<br>This register records the number of packages which has been completed in one transmission. |

## 3.12 Thermal Sensor Controller (THS)

### 3.12.1 Overview

The thermal sensors are common elements in wide range of modern system on chips (SoCs) platform. The thermal sensors are used to constantly monitor the temperature on the chip.

The thermal sensor controller (THS) embeds one thermal sensor located in the CPU. When the temperature reaches a certain thermal threshold, the thermal sensor can generate interrupts to the software to lower the temperature via the dynamic voltage and frequency scaling (DVFS) technology.

The THS has the following features:

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

### 3.12.2 Block Diagram

The following figure shows a block diagram of the THS.

Figure 3-26 THS Block Diagram



### 3.12.3 Functional Description

#### 3.12.3.1 Clock Source

The THS gets one clock source: OSC24M. For details about clock configurations, refer to section 3.3 “[CCU](#)”.

### 3.12.3.2 Timing Requirements

The following figure shows the timing requirements for the THS.

Figure 3-27 Thermal Sensor Timing Requirement



CLK\_IN = 24 MHz

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

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

THERMAL\_PER > ADC\_Sample\_Frequency > TACQ + CONV\_TIME

### 3.12.3.3 Interrupts

The THS has four interrupt sources: DATA\_IRQ, SHUTDOWN\_IRQ, ALARM\_IRQ, and ALARM\_OFF\_IRQ. The following figure shows thermal sensor interrupt sources.

Figure 3-28 Thermal Sensor Controller Interrupt Source



**DATA\_IRQ:** The interrupt is generated when the measured sensor\_data is updated.

**SHUTDOWN\_IRQ:** The interrupt is generated when the temperature is higher than the shutdown threshold.

**ALARM\_IRQ:** The interrupt is generated when the temperature is higher than the Alarm\_Threshold.

**ALARM\_OFF\_IRQ:** The interrupt is generated when the temperature drops to lower than the Alarm\_Off\_Threshold. It is triggered at the fall edge.

### 3.12.3.4 THS Temperature Conversion Formula

$$T = (\text{sensor\_data} - 2800) / (-14.85)$$

Unit of T: Celsius degree (°C).

The sensor\_data is read from the sensor data register.

### 3.12.4 Programming Guidelines

The initial process of the THS is as follows.

**Figure 3-29 THS Initial Process**



In the final test (FT) stage, the THS is calibrated through the ambient temperature, and the calibration value is written in the SID module. The following table shows the THS information in the SID.

**Table 3-16 THS Information in the SID**

| Base Address: 0x14 | Register Name: THS                     |
|--------------------|----------------------------------------|
| Bit                | Description                            |
| 27:16              | The calibration value of the T-sensor. |

Before enabling THS, read eFuse value and write the value to [THS\\_CDATA](#).

#### Query Mode

**Step 1** Write 0x1 to the bit[16] of [THS\\_BGR\\_REG](#) to dessert the reset.

- Step 2** Write 0x1 to the bit[0] of [THS\\_BGR\\_REG](#) to open the THS clock.
- Step 3** Write 0x2F to the bit[15:0] of [THS\\_CTRL](#) to set the ADC acquire time.
- Step 4** Write 0x1DF to the bit[31:16] of [THS\\_CTRL](#) to set the ADC sample frequency divider.
- Step 5** Write 0x3A to the bit[31:12] of [THS\\_PER](#) to set the THS work period.
- Step 6** Write 0x1 to the bit[2] of [THS\\_FILTER](#) to enable the temperature convert filter.
- Step 7** Write 0x1 to the bit[1:0] of [THS\\_FILTER](#) to select the filter type.
- Step 8** Read THS eFuse value from SID, then write the eFuse value to [THS\\_CDATA](#) to calibrate THS.
- Step 9** Write 0x1 to the bit[0] of [THSO\\_EN](#) to enable THS.
- Step 10** Read the bit[0] of [THS\\_DATA\\_INTS](#). If it is 1, the temperature conversion is complete.
- Step 11** Read the bit[11:0] of [THS\\_DATA](#), and calculate the THS temperature based on section 3.12.3.4 "[THS Temperature Conversion Formula](#)".

#### Interrupt Mode

- Step 1** Write 0x1 to the bit16 of [THS\\_BGR\\_REG](#) to dessert the reset.
- Step 2** Write 0x1 to the bit0 of [THS\\_BGR\\_REG](#) to open the THS clock.
- Step 3** Write 0x2F to the bit[15:0] of [THS\\_CTRL](#) to set the ADC acquire time.
- Step 4** Write 0x1DF to the bit[31:16] of [THS\\_CTRL](#) to set the ADC sample frequency divider.
- Step 5** Write 0x3A to the bit[31:12] of [THS\\_PER](#) to set the THS work period.
- Step 6** Write 0x1 to the bit2 of [THS\\_FILTER](#) to enable the temperature convert filter.
- Step 7** Write 0x1 to the bit[1:0] of [THS\\_FILTER](#) to select the filter type.
- Step 8** Read THS eFuse value from SID, and then write the eFuse value to [THS\\_CDATA](#) to calibrate THS.
- Step 9** Write 0x1 to the bit[0] of [THS\\_DATA\\_INTC](#) to enable the interrupt of THS.
- Step 10** Set interrupt based on GIC module.
- Step 11** Put the interrupt handler address into the interrupt vector table.
- Step 12** Write 0x1 to the bit[0] of [THSO\\_EN](#) to enable THS.
- Step 13** Read the bit[0] of [THS\\_DATA\\_INTS](#). If it is 1, the temperature conversion is complete.
- Step 14** Read the bit[11:0] of [THS\\_DATA](#), and calculate the THS temperature based on section 3.12.3.4 "[THS Temperature Conversion Formula](#)".

### 3.12.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| THS         | 0x02009400   |

| Register Name     | Offset | Description                             |
|-------------------|--------|-----------------------------------------|
| THS_CTRL          | 0x0000 | THS Control Register                    |
| THS_EN            | 0x0004 | THS Enable Register                     |
| THS_PER           | 0x0008 | THS Period Control Register             |
| THS_DATA_INTC     | 0x0010 | THS Data Interrupt Control Register     |
| THS_SHUT_INTC     | 0x0014 | THS Shut Interrupt Control Register     |
| THS_ALARM_INTC    | 0x0018 | THS Alarm Interrupt Control Register    |
| THS_DATA_INTS     | 0x0020 | THS Data Interrupt Status Register      |
| THS_SHUT_INTS     | 0x0024 | THS Shut Interrupt Status Register      |
| THS_ALARMO_INTS   | 0x0028 | THS Alarm off Interrupt Status Register |
| THS_ALARM_INTS    | 0x002C | THS Alarm Interrupt Status Register     |
| THS_FILTER        | 0x0030 | THS Median Filter Control Register      |
| THS_ALARM_CTRL    | 0x0040 | THS Alarm Threshold Control Register    |
| THS_SHUTDOWN_CTRL | 0x0080 | THS Shutdown Threshold Control Register |
| THS_CDATA         | 0x00A0 | THS Calibration Data                    |
| THS_DATA          | 0x00C0 | THS Data Register                       |

### 3.12.6 Register Description

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

| Offset: 0x0000 |            |             | Register Name: THS_CTRL                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:16          | R/W        | 0x1DF       | TACQ<br>ADC acquire time<br>CLK_IN/(n + 1)<br>The default value is 2 us. |
| 15:0           | R/W        | 0x2F        | Reserved                                                                 |

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

| Offset: 0x0004 |            |             | Register Name: THS_EN                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 31:1           | /          | /           | /                                                                          |
| 0              | R/W        | 0x0         | THS_EN<br>Enable temperature measurement sensor<br>0: Disable<br>1: Enable |

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

| Offset: 0x0008 |            |             | Register Name: THS_PER                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31:12          | R/W        | 0x3A        | THERMAL_PER<br>Temperature measurement period<br>$4096 \times (n + 1) / CLK\_IN$<br>The default value is 10 ms. |
| 11:0           | /          | /           | /                                                                                                               |

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

| Offset: 0x0010 |            |             | Register Name: THS_DATA_INTC                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:1           | /          | /           | /                                                                                                                                                                                  |
| 0              | R/W        | 0x0         | THS_DATA_IRQ_EN<br>Enable the interrupt of sensor_data update<br>If enabled, when the measured sensor_data is updated, it will generate an interrupt.<br>0: Disabled<br>1: Enabled |

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

| Offset: 0x0014 |            |             | Register Name: THS_SHUT_INTC                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:1           | /          | /           | /                                                                                        |
| 0              | R/W        | 0x0         | SHUT_INT_EN<br>Enable the shutdown interrupt for the sensor<br>0: Disabled<br>1: Enabled |

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

| Offset: 0x0018 |            |             | Register Name: THS_ALARM_INTC                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:1           | /          | /           | /                                                                                      |
| 0              | R/W        | 0x0         | ALARM_INT_EN<br>Enable the alarm interrupt for the sensor<br>0: Disabled<br>1: Enabled |

### 3.12.6.7 0x0020 THS Data Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: THS_DATA_INTS                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:1           | /          | /           | /                                                                                                                                                   |
| 0              | R/W1C      | 0x0         | THS_DATA_IRQ_STS<br>Indicates the pending status of the sensor's data interrupt. Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

**3.12.6.8 0x0024 THS Shut Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0024 |            |             | Register Name: THS_SHUT_INTS                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:1           | /          | /           | /                                                                                                                                                             |
| 0              | R/W1C      | 0x0         | <b>SHUT_INT_STS</b><br>Indicates the pending status of the sensor's shutdown interrupt.<br>Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

**3.12.6.9 0x0028 THS Alarm Off Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0028 |            |             | Register Name: THS_ALARM_INTS                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                          |
| 31:1           | /          | /           | /                                                                                                                                    |
| 0              | R/W1C      | 0x0         | <b>ALARM_OFF_STS</b><br>Alarm interrupt off pending for sensor<br>Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

**3.12.6.10 0x002C THS Alarm Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x002C |            |             | Register Name: THS_ALARM_INTS                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:1           | /          | /           | /                                                                                                                                |
| 0              | R/W1C      | 0x0         | <b>ALARM_INT_STS</b><br>Alarm interrupt pending for sensor<br>Write 1 to clear the pending status.<br>0: No effect<br>1: Pending |

### 3.12.6.11 0x0030 Median Filter Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0030 |            |             | Register Name: THS_FILTER                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:3           | /          | /           | /                                                                         |
| 2              | R/W        | 0x0         | FILTER_EN<br>Filter enable<br>0: Disabled<br>1: Enabled                   |
| 1:0            | R/W        | 0x1         | FILTER_TYPE<br>Averaging filter type<br>00: 2<br>01: 4<br>10: 8<br>11: 16 |

### 3.12.6.12 0x0040 THS Alarm Threshold Control Register (Default Value: 0x05A0\_0684)

| Offset: 0x0040 |            |             | Register Name: THS_ALARM_CTRL                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:28          | /          | /           | /                                                                         |
| 27:16          | R/W        | 0x5A0       | ALARM_T_HOT<br>Thermal sensor alarm threshold for hot temperature         |
| 15:12          | /          | /           | /                                                                         |
| 11:0           | R/W        | 0x684       | ALARM_T_HYST<br>Thermal sensor alarm threshold for hysteresis temperature |

### 3.12.6.13 0x0080 THS Shutdown Threshold Control Register (Default Value: 0x0000\_04E9)

| Offset: 0x0080 |            |             | Register Name: THS_SHUTDOWN_CTRL                                    |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:28          | /          | /           | /                                                                   |
| 11:0           | R/W        | 0x4E9       | SHUT_T_HOT<br>Thermal sensor shutdown threshold for hot temperature |

**3.12.6.14 0x00A0 THS Calibration Data Register (Default Value: 0x0000\_0800)**

| Offset: 0x00A0 |            |             | Register Name: THS_CDATA                     |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:12          | /          | /           | /                                            |
| 11:0           | R/W        | 0x800       | THS_CDATA<br>Thermal sensor calibration data |

**3.12.6.15 0x00C0 THS Data Register (Default Value: 0x0000\_0000)**

| Offset: 0x00C0 |            |             | Register Name: THS_DATA                            |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:12          | /          | /           | /                                                  |
| 11:0           | R          | 0x0         | THS_DATA<br>Temperature measurement data of sensor |

## 3.13 IOMMU

### 3.13.1 Overview

The I/O Memory management unit (IOMMU) is designed for the specific memory requirements of products. It maps the virtual address (sent by peripheral access memory) to the physical address. The IOMMU allows multiple ways to manage the location of physical address, and it can use physical address which has potentially conflict mapping for different processes to allocate memory space, and also allow application of non-continuous address mapping to continuous virtual address space.

#### Features:

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

### 3.13.2 Block Diagram

The internal module of IOMMU mainly has the following parts.

**Micro TLB:** level1 TLB, 64 words. Each peripheral corresponds to a TLB, which caching the level2 page table for the peripheral.

**Macro TLB:** level2 TLB, 4K words. Each peripheral shares a level2 TLB for caching the level2 page table.

**Prefetch Logic:** Each Micro TLB corresponds to a Prefetch Logic. By monitoring each master device to predict the bus access, the secondary page table corresponding to the address to be accessed can be read from memory and stored in the secondary TLB to improve hit ratio.

**PTW Logic:** Page Table Walk, mainly contains PTW Cache and PTW. The PTW Cache is used to store the level1 page table; when the virtual address VA missed in the level1 and level2 TLB, it will trigger the PTW. PTW Cache can store 512 level1 page tables, that is, 512 words.

**PMU:** Performance Monitoring Unit, which is used to count hit efficiency and latency.

**APB Interface:** IOMMU register instantiation module. CPU reads and writes the IOMMU register by APB bus.

The following figure shows the internal block diagram of IOMMU.

**Figure 3-30 IOMMU Block Diagram**



**Table 3-17 Correspondence Relation between Master and Module**

| Master Number | Module |
|---------------|--------|
| Master0       | VE     |
| Master1       | CSI    |
| Master2       | DE     |
| Master3       | G2D    |
| Master4       | DI     |

### 3.13.3 Functional Description

#### 3.13.3.1 Initialization

- Release the IOMMU reset signal by writing 1 to [IOMMU RESET REG\[31\]](#);

- Write the base address of the first TLB to [IOMMU\\_TTB\\_REG](#);
- Set [IOMMU\\_INT\\_ENABLE\\_REG](#);
- Enable the IOMMU by configuring [IOMMU\\_ENABLE\\_REG](#) in the final.

### 3.13.3.2 Address Changing

In the process of address mapping, The peripheral virtual address VA[31:12] are retrieved in the Level1 TLB, when TLB hits, the mapping finished, or they are retrieved in the Level2 TLB in the same way. If TLB hits, it will write the hit mapping to the Level1 TLB, and hits in Level1 TLB. If Level1 and Level2 TLB are retrieved fail, it will trigger the PTW. After opening peripheral bypass function by setting IOMMU Bypass Register, IOMMU will not map the address for peripheral typed the address, and it will output the virtual address as physical address.

The typical scenarios are as follows.

#### Micro TLB hit

- Step 1** The master device sends a transfer command to send the address to the corresponding Micro TLB, and searches the Level2 page table corresponding to virtual address;
- Step 2** If Micro TLB hits, it will return a corresponding physical addresses and the Level2 page table of permission Index;
- Step 3** Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, the transfer is completed.

#### Micro TLB miss, Macro TLB hit

- Step 1** The master device sends a transfer command to send the address to the corresponding Micro TLB, and searches the Level2 page table corresponding to virtual address;
- Step 2** If Micro TLB misses, then continue to search Macro TLB;
- Step 3** If Macro TLB hits, it will return the Level2 page table to Micro TLB;
- Step 4** Micro TLB receives the page table and puts it to Micro TLB (if this Micro TLB is full, there will happen the replace activity), at the same time, the page table entry is sent to address translation module;
- Step 5** Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, the transfer is completed.

### Micro TLB miss, Macro TLB miss, PTW Cache hit

- Step 1** The master device sends a transfer command to send the address to the corresponding Micro TLB, and searches the Level2 page table corresponding to virtual address;
- Step 2** If Micro TLB misses, then continue to search Macro TLB;
- Step 3** If Macro TLB misses, then it will send the request to the PTW to return the corresponding page table;
- Step 4** PTW first accesses PTW Cache, confirms that the required Level1 page table exists in the PTW Cache, sends the page table to PTW logic;
- Step 5** PTW logic returns the corresponding Level2 page table from memory page table according to Level1 page table, checks the effectiveness, and sends to Macro TLB;
- Step 6** Macro TLB stores the Level2 page table (there may happen the replace activity), and will return the Level2 page table to Micro TLB;
- Step 7** Micro TLB receives the page table entries and puts it to the Micro TLB (if this Micro TLB is full, there will happen the replace activity), and sends page table entries to address translation module;
- Step 8** Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, the transfer is completed.

### Micro TLB miss, Macro TLB miss, PTW Cache miss

- Step 1** The master device sends a transfer command to send the address to the corresponding Micro TLB, and searches the Level2 page table corresponding to virtual address;
- Step 2** If Micro TLB misses, then continue to search Macro TLB;
- Step 3** If Macro TLB misses, there will send the request to the PTW to return the corresponding page table;
- Step 4** PTW accesses PTW Cache, the Level1 page table is unnecessary;
- Step 5** PTW accesses memory to get the corresponding Level1 page table and stores it to the PTW Cache (there may happen the replace activity);
- Step 6** PTW logic returns the corresponding Level2 page table from memory page table according to Level1 page table, checks the effectiveness, and sends to Macro TLB;
- Step 7** Macro TLB stores the Level2 page table (there may happen the replace activity), and returns the Level2 page table to Micro TLB;
- Step 8** Micro TLB receives the page table entries and puts it to the Micro TLB (if this Micro TLB is full, there will happen the replace activity), and sends page table entries to address translation module;
- Step 9** Address transform module converts the virtual address into physical address, and checks the permissions at the same time. If pass, the transfer is completed.

### Permission error

- Step 1** Permission checking always performs in the address conversion;
- Step 2** Once the permission checking makes mistake, the new access of the master suspends, but continues before this access;
- Step 3** Set the error status register;
- Step 4** Trigger interrupt.

### Invalid Level1 page table

- Step 1** Invalid Level1 page table is checked when PTW logic reads the new level page table from memory;
- Step 2** The PTW reads sequentially two page table entries from the memory (64-bit data, a complete cache line), and stores in the PTW cache;
- Step 3** If the current page table is detected invalid, then the error flag is set, and the interrupt is triggered, the cache line need to be invalidated.



#### NOTE

- Invalid page table has two situations: the reading target page table from the memory is invalid; and the page table stored in PTW Cache with target page table is found to be invalid after using;
- If a page table is invalid, then the total cache line (that is two page tables) need to be invalidated.

### Invalid Level2 page table

- Step 1** Invalid Level2 page table checks when Macro TLB reads the new level page table from memory;
- Step 2** The Macro TLB reads sequentially two page table entries from the memory (64-bit data, a complete cache line), and stores in the Macro TLB;
- Step 3** If the current page table is detected invalid, then the error flag is set, and the interrupt is triggered, the cache line need to be invalidated.

**NOTE**

- Invalid page table has two situations: the reading target page table from the memory is invalid; and the page table stored in Macro TLB with target page table is found to be invalid after using.
- If a page table is invalid, then the total cache line (that is two page tables) need to be invalidated.

The following figure shows the internal address switch process.

**Figure 3-31 Internal Switch Process**



### 3.13.3.3 VA-PA Mapping

IOMMU page table is defined as Level2 mapping, the first level is 1M address space mapping, the second level is 4K address space. This version does not support 1K, 16K and other page table size. IOMMU supports a page table only, its meaning is:

- All peripherals connected to IOMMU use the same virtual address space;
- The virtual address space of the peripherals can overlap;
- Different virtual addresses can map to the same physical address space;

Base address of the page table is defined by software, and it needs 16 KB address alignment; Page table of the Level2 table item needs 1 KB address alignment. The following figure shows a complete VA-PA address translation process.

Figure 3-32 VA-PA Switch Process



### 3.13.3.4 Clear and Invalidate TLB

When the content of multi page tables refreshes or the address of page table changes, all VA-PA mapping which has been cached in TLB will no longer be valid, then you need configure **IOMMU TLB Flush Enable Register** to clear the TLB or PTW Cache. First suspend the access to TLB or Cache, then configure the corresponding Flush bit of **IOMMU TLB Flush Enable Register**, after the operation takes effect, the related peripherals can continue to send new access memory operations.

When some page table is invalid or incorrect mapping, you can set the TLB Invalidations relevant register to invalidate some TLB VA-PA mapping pairs. There are two modes to invalidate the TLB operation.

#### (1) Mode0 (Old mode)

- Step 1** Set **IOMMU TLB Invalid Mode Select Register** to 0 to select mode0;
- Step 2** Write target address to **IOMMU TLB Invalid Address Register**;
- Step 3** Set configuration values to **IOMMU TLB Invalid Address Mask Register**, the requirements are as follows:
  - The value of **IOMMU TLB Invalid Address Mask Register** cannot be less than the **IOMMU TLB Invalid Address Register**.
  - The higher bit of **IOMMU TLB Invalid Address Mask Register** must be continuous 1, the lower bit must be continuous 0. For example, 0xfffff000, 0xffffe000, 0xffffc000, 0xffff8000, 0xffff0000 belongs to the legal value; and 0xffffd000, 0xffffb000, 0xffffa000, 0xffff9000, 0xffff7000 belongs to the illegal values.
- Step 4** Configure **IOMMU TLB Invalid Enable Register** to enable the invalid operation. Among the way to determine the invalid address is to get maximum valid bit and determine target address range by target address AND mask address. The following figure shows the process.

Figure 3-33 Invalid TLB Address Range



For example:

- a) When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFF000 by default, the result of AND is target address, that is, only target address is invalid.
- b) When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFF0000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE1000, then the range of target address is from 0xEEEE0000 to 0xEEEF000.
- c) When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFC000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE8000, then the range of target address is from 0xEEEE8000 to 0xEEEB000.
- d) When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFF8000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEC000, then the range of target address is from 0xEEEE8000 to 0xEEEF000.
- e) When the value of **IOMMU TLB Invalid Address Mask Register** is 0xFFFFC000, the value of **IOMMU TLB Invalid Address Register** is 0xEEEE0000, then the range of target address is from 0xEEEE0000 to 0xEEE3000.

## (2) Mode1 (New mode)

**Step 1** Set **IOMMU TLB Invalid Mode Select Register** to 1 to select mode1;

**Step 2** Set the starting address of invalid TLB by **IOMMU TLB Invalid Start Address Register**, and set the ending address of invalid TLB by **IOMMU TLB Invalid End Address Register**;

**Step 3** Configure **IOMMU TLB Invalid Enable Register** to enable invalid operation, then the related TLB operation is invalidated.

### 3.13.3.5 Clear and Invalidate PTW Cache

There are two modes to invalidate the PTW cache operation.

## (1) Mode0 (Old mode)

**Step 1** Set **IOMMU PC Invalid Mode Select Register** to 0 to select mode0;

**Step 2** Set the address register that needs to be invalidated to **IOMMU PC Invalid Address Register** (the addresses need to be aligned with 1 MB);

**Step 3** Configure **IOMMU PC Invalid Enable Register** to enable the invalid operation. That is, the PTW cache operation of a cacheline is invalidated.

## (2) Mode1 (New mode)

- Step 1 Set **IOMMU PC Invalid Mode Select Register** to 1 to select mode1;
- Step 2 Set the starting address of invalid TLB by **IOMMU PTW Invalid Start Address Register**, and set the ending address of invalid TLB by **IOMMU PC Invalid Start Address Register**;
- Step 3 Configure **IOMMU PC Invalid Enable Register** to enable invalid operation, then to invalid the related PWM cache operation is completed.

### 3.13.3.6 Page Table Format

#### Level1 Page Table

The format of Level1 page table is as follows.

Figure 3-34 Level1 Page Table Format

|                                    |          |       |
|------------------------------------|----------|-------|
| 31                                 | 109      | 2 1 0 |
| Start address of Level2 page table | Reserved | 01    |

Bit[31:10]: Base address of Level2 page table;

Bit[9:2]: Reserved;

Bit[1:0]: 01 is valid page table; others are fault;

#### Level2 Page Table

The format of Level2 page table is as follows.

Figure 3-35 Level1 Page Table Format

|                       |    |     |   |     |
|-----------------------|----|-----|---|-----|
| 31                    | 12 | 7   | 4 | 1 0 |
| Physical base address |    | ACI |   | 1   |

Bit[31:12]: Physical address of 4K address;

Bit[11:8]: Reserved;

Bit[7:4]: ACI, permission control index; correspond to permission control bit of **IOMMU Domain Authority Control Register**;

Bit[3:2]: Reserved;

Bit[1]: 1 is valid page table; 0 is fault;

Bit[0]: Reserved

## Permission Index

The read/write access control of series register such as **IOMMU Domain Authority Control Register** is as follows.

Figure 3-36 Read/Write Permission Control

|    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| W  | R  | W  | R  | W | R | W | R | W | R | W | R | W | R |

Bit[1:0]/Bit[17:16]: Master0 read/write permission control;

Bit[3:2]/Bit[19:18]: Master1 read/write permission control;

Bit[5:4]/Bit[21:20]: Master2 read/write permission control;

Bit[7:6]/Bit[23:22]: Master3 read/write permission control;

Bit[9:8]/Bit[25:24]: Master4 read/write permission control;

Bit[11:10]/Bit[27:26]: Master5 read/write permission control;

Bit[13:12]/Bit[29:28]: Master6 read/write permission control.

The value of **IOMMU Domain Authority Control Register** is read-only by default. Other registers can configure through system requirement. In address switch process, the corresponding relation between ACI and Domain is as follows.

Table 3-18 Relation between ACI and Domain

| ACI | Domain    | Register                                  |
|-----|-----------|-------------------------------------------|
| 0   | Domain 0  | IOMMU Domain Authority Control Register 0 |
| 1   | Domain 1  | IOMMU Domain Authority Control Register 0 |
| 2   | Domain 2  | IOMMU Domain Authority Control Register 1 |
| 3   | Domain 3  | IOMMU Domain Authority Control Register 1 |
| 4   | Domain 4  | IOMMU Domain Authority Control Register 2 |
| 5   | Domain 5  | IOMMU Domain Authority Control Register 2 |
| 6   | Domain 6  | IOMMU Domain Authority Control Register 3 |
| 7   | Domain 7  | IOMMU Domain Authority Control Register 3 |
| 8   | Domain 8  | IOMMU Domain Authority Control Register 4 |
| 9   | Domain 9  | IOMMU Domain Authority Control Register 4 |
| 10  | Domain 10 | IOMMU Domain Authority Control Register 5 |
| 11  | Domain 11 | IOMMU Domain Authority Control Register 5 |

| ACI | Domain    | Register                                  |
|-----|-----------|-------------------------------------------|
| 12  | Domain 12 | IOMMU Domain Authority Control Register 6 |
| 13  | Domain 13 | IOMMU Domain Authority Control Register 6 |
| 14  | Domain 14 | IOMMU Domain Authority Control Register 7 |
| 15  | Domain 15 | IOMMU Domain Authority Control Register 7 |

After enabled **IOMMU Domain Authority Overwrite Register**, the read/write control permission can override all **IOMMU Domain Authority Control Register**.

### 3.13.4 Programming Guidelines

#### 3.13.4.1 Resetting IOMMU

Before the IOMMU module software reset operation, make sure IOMMU is never opened, or all bus operations are completed, or DRAM and peripherals already open the corresponding switch, to shield the influence of IOMMU reset.

#### 3.13.4.2 Enabling IOMMU

Before opening the IOMMU address mapping function, the **Translation Table Base Register** should be correctly configured, or all the masters are in the bypass state, or all the masters do not send the bus command.

#### 3.13.4.3 Configuring TTB

Operating the register must close the address mapping function of IOMMU, that is, the IOMMU\_ENABLE\_REG[0] is 0; or the bypass function of all masters is set to 1; or the state of the TX bus command is none.

#### 3.13.4.4 Clearing TTB

In the Flush operation, all TLB/Cache access will be suspended; but the operation entered the TLB will continue to complete before the Flush starts.

### 3.13.4.5 Reading/Writing VA Data

For target virtual address, read and write the corresponding physical address data to make sure whether IOMMU module address mapping function is normal. First, make sure to read or write, and then configure the target virtual address or write data, then start to read or write function, check whether the results are as expected after the operation is finished.

### 3.13.4.6 Using PMU Statistics Function

When PMU function is used for the first time, set **IOMMU PMU Enable Register** to enable statistics function; when reading the relevant Register, clear the enable bit of **IOMMU PMU Enable Register**; when PMU function is used next time, first **IOMMU PMU Clear Register** is set, after counter is cleared, set the enable bit of **IOMMU PMU Enable Register**.

Given a Level2 page table administers continuous 4 KB address, if Micro TLB misses in continuous virtual address, there may need to return a Level2 page table to hit from Macro TLB; but the hit number is not recorded in the Macro TLB hit and Micro TLB hit related register. So the true hit rate calculation is as follows:

$$\text{Hit Rate} = N1/M1 + (1-N1/M1)*N2/M2$$

N1: Micro TLB hit number

M1: Micro TLB access number

N2: Macro TLB hit number

M2: Macro TLB access number

## 3.13.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| IOMMU       | 0x02010000   |

| Register Name              | Offset | Description                                 |
|----------------------------|--------|---------------------------------------------|
| IOMMU_RESET_REG            | 0x0010 | IOMMU Reset Register                        |
| IOMMU_ENABLE_REG           | 0x0020 | IOMMU Enable Register                       |
| IOMMU_BYPASS_REG           | 0x0030 | IOMMU Bypass Register                       |
| IOMMU_AUTO_GATING_REG      | 0x0040 | IOMMU Auto Gating Register                  |
| IOMMU_WBUF_CTRL_REG        | 0x0044 | IOMMU Write Buffer Control Register         |
| IOMMU_OOO_CTRL_REG         | 0x0048 | IOMMU Out of Order Control Register         |
| IOMMU_4KB_BDY_PRT_CTRL_REG | 0x004C | IOMMU 4KB Boundary Protect Control Register |

| Register Name                | Offset | Description                                     |
|------------------------------|--------|-------------------------------------------------|
| IOMMU_TTB_REG                | 0x0050 | IOMMU Translation Table Base Register           |
| IOMMU_TLB_ENABLE_REG         | 0x0060 | IOMMU TLB Enable Register                       |
| IOMMU_TLB_PREFETCH_REG       | 0x0070 | IOMMU TLB Prefetch Register                     |
| IOMMU_TLB_FLUSH_ENABLE_REG   | 0x0080 | IOMMU TLB Flush Enable Register                 |
| IOMMU_TLB_IVLD_MODE_SEL_REG  | 0x0084 | IOMMU TLB Invalidation Mode Select Register     |
| IOMMU_TLB_IVLD_STA_ADDR_REG  | 0x0088 | IOMMU TLB Invalidatation Start Address Register |
| IOMMU_TLB_IVLD_END_ADDR_REG  | 0x008C | IOMMU TLB Invalidatation End Address Register   |
| IOMMU_TLB_IVLD_ADDR_REG      | 0x0090 | IOMMU TLB Invalidatation Address Register       |
| IOMMU_TLB_IVLD_ADDR_MASK_REG | 0x0094 | IOMMU TLB Invalidatation Address Mask Register  |
| IOMMU_TLB_IVLD_ENABLE_REG    | 0x0098 | IOMMU TLB Invalidatation Enable Register        |
| IOMMU_PC_IVLD_MODE_SEL_REG   | 0x009C | IOMMU PC Invalidatation Mode Select Register    |
| IOMMU_PC_IVLD_ADDR_REG       | 0x00A0 | IOMMU PC Invalidatation Address Register        |
| IOMMU_PC_IVLD_STA_ADDR_REG   | 0x00A4 | IOMMU PC Invalidatation Start Address Register  |
| IOMMU_PC_IVLD_ENABLE_REG     | 0x00A8 | IOMMU PC Invalidatation Enable Register         |
| IOMMU_PC_IVLD_END_ADDR_REG   | 0x00AC | IOMMU PC Invalidatation End Address Register    |
| IOMMU_DM_AUT_CTRL0_REG       | 0x00B0 | IOMMU Domain Authority Control 0 Register       |
| IOMMU_DM_AUT_CTRL1_REG       | 0x00B4 | IOMMU Domain Authority Control 1 Register       |
| IOMMU_DM_AUT_CTRL2_REG       | 0x00B8 | IOMMU Domain Authority Control 2 Register       |
| IOMMU_DM_AUT_CTRL3_REG       | 0x00BC | IOMMU Domain Authority Control 3 Register       |
| IOMMU_DM_AUT_CTRL4_REG       | 0x00C0 | IOMMU Domain Authority Control 4 Register       |
| IOMMU_DM_AUT_CTRL5_REG       | 0x00C4 | IOMMU Domain Authority Control 5 Register       |
| IOMMU_DM_AUT_CTRL6_REG       | 0x00C8 | IOMMU Domain Authority Control 6 Register       |
| IOMMU_DM_AUT_CTRL7_REG       | 0x00CC | IOMMU Domain Authority Control 7 Register       |
| IOMMU_DM_AUT_OVWT_REG        | 0x00D0 | IOMMU Domain Authority Overwrite Register       |
| IOMMU_INT_ENABLE_REG         | 0x0100 | IOMMU Interrupt Enable Register                 |
| IOMMU_INT_CLR_REG            | 0x0104 | IOMMU Interrupt Clear Register                  |
| IOMMU_INT_STA_REG            | 0x0108 | IOMMU Interrupt Status Register                 |
| IOMMU_INT_ERR_ADDR0_REG      | 0x0110 | IOMMU Interrupt Error Address 0 Register        |
| IOMMU_INT_ERR_ADDR1_REG      | 0x0114 | IOMMU Interrupt Error Address 1 Register        |
| IOMMU_INT_ERR_ADDR2_REG      | 0x0118 | IOMMU Interrupt Error Address 2 Register        |
| IOMMU_INT_ERR_ADDR3_REG      | 0x011C | IOMMU Interrupt Error Address 3 Register        |
| IOMMU_INT_ERR_ADDR4_REG      | 0x0120 | IOMMU Interrupt Error Address 4 Register        |
| IOMMU_INT_ERR_ADDR5_REG      | 0x0124 | IOMMU Interrupt Error Address 5 Register        |
| IOMMU_INT_ERR_ADDR6_REG      | 0x0128 | IOMMU Interrupt Error Address 6 Register        |

| Register Name              | Offset | Description                                  |
|----------------------------|--------|----------------------------------------------|
| IOMMU_INT_ERR_ADDR7_REG    | 0x0130 | IOMMU Interrupt Error Address 7 Register     |
| IOMMU_INT_ERR_ADDR8_REG    | 0x0134 | IOMMU Interrupt Error Address 8 Register     |
| IOMMU_INT_ERR_DATA0_REG    | 0x0150 | IOMMU Interrupt Error Data 0 Register        |
| IOMMU_INT_ERR_DATA1_REG    | 0x0154 | IOMMU Interrupt Error Data 1 Register        |
| IOMMU_INT_ERR_DATA2_REG    | 0x0158 | IOMMU Interrupt Error Data 2 Register        |
| IOMMU_INT_ERR_DATA3_REG    | 0x015C | IOMMU Interrupt Error Data 3 Register        |
| IOMMU_INT_ERR_DATA4_REG    | 0x0160 | IOMMU Interrupt Error Data 4 Register        |
| IOMMU_INT_ERR_DATA5_REG    | 0x0164 | IOMMU Interrupt Error Data 5 Register        |
| IOMMU_INT_ERR_DATA6_REG    | 0x0168 | IOMMU Interrupt Error Data 6 Register        |
| IOMMU_INT_ERR_DATA7_REG    | 0x0170 | IOMMU Interrupt Error Data 7 Register        |
| IOMMU_INT_ERR_DATA8_REG    | 0x0174 | IOMMU Interrupt Error Data 8 Register        |
| IOMMU_L1PG_INT_REG         | 0x0180 | IOMMU L1 Page Table Interrupt Register       |
| IOMMU_L2PG_INT_REG         | 0x0184 | IOMMU L2 Page Table Interrupt Register       |
| IOMMU_VA_REG               | 0x0190 | IOMMU Virtual Address Register               |
| IOMMU_VA_DATA_REG          | 0x0194 | IOMMU Virtual Address Data Register          |
| IOMMU_VA_CONFIG_REG        | 0x0198 | IOMMU Virtual Address Configuration Register |
| IOMMU_PMU_ENABLE_REG       | 0x0200 | IOMMU PMU Enable Register                    |
| IOMMU_PMU_CLR_REG          | 0x0210 | IOMMU PMU Clear Register                     |
| IOMMU_PMU_ACCESS_LOW0_REG  | 0x0230 | IOMMU PMU Access Low 0 Register              |
| IOMMU_PMU_ACCESS_HIGH0_REG | 0x0234 | IOMMU PMU Access High 0 Register             |
| IOMMU_PMU_HIT_LOW0_REG     | 0x0238 | IOMMU PMU Hit Low 0 Register                 |
| IOMMU_PMU_HIT_HIGH0_REG    | 0x023C | IOMMU PMU Hit High 0 Register                |
| IOMMU_PMU_ACCESS_LOW1_REG  | 0x0240 | IOMMU PMU Access Low 1 Register              |
| IOMMU_PMU_ACCESS_HIGH1_REG | 0x0244 | IOMMU PMU Access High 1 Register             |
| IOMMU_PMU_HIT_LOW1_REG     | 0x0248 | IOMMU PMU Hit Low 1 Register                 |
| IOMMU_PMU_HIT_HIGH1_REG    | 0x024C | IOMMU PMU Hit High 1 Register                |
| IOMMU_PMU_ACCESS_LOW2_REG  | 0x0250 | IOMMU PMU Access Low 2 Register              |
| IOMMU_PMU_ACCESS_HIGH2_REG | 0x0254 | IOMMU PMU Access High 2 Register             |
| IOMMU_PMU_HIT_LOW2_REG     | 0x0258 | IOMMU PMU Hit Low 2 Register                 |
| IOMMU_PMU_HIT_HIGH2_REG    | 0x025C | IOMMU PMU Hit High 2 Register                |
| IOMMU_PMU_ACCESS_LOW3_REG  | 0x0260 | IOMMU PMU Access Low 3 Register              |
| IOMMU_PMU_ACCESS_HIGH3_REG | 0x0264 | IOMMU PMU Access High 3 Register             |
| IOMMU_PMU_HIT_LOW3_REG     | 0x0268 | IOMMU PMU Hit Low 3 Register                 |
| IOMMU_PMU_HIT_HIGH3_REG    | 0x026C | IOMMU PMU Hit High 3 Register                |

| Register Name              | Offset | Description                         |
|----------------------------|--------|-------------------------------------|
| IOMMU_PMU_ACCESS_LOW4_REG  | 0x0270 | IOMMU PMU Access Low 4 Register     |
| IOMMU_PMU_ACCESS_HIGH4_REG | 0x0274 | IOMMU PMU Access High 4 Register    |
| IOMMU_PMU_HIT_LOW4_REG     | 0x0278 | IOMMU PMU Hit Low 4 Register        |
| IOMMU_PMU_HIT_HIGH4_REG    | 0x027C | IOMMU PMU Hit High 4 Register       |
| IOMMU_PMU_ACCESS_LOW5_REG  | 0x0280 | IOMMU PMU Access Low 5 Register     |
| IOMMU_PMU_ACCESS_HIGH5_REG | 0x0284 | IOMMU PMU Access High 5 Register    |
| IOMMU_PMU_HIT_LOW5_REG     | 0x0288 | IOMMU PMU Hit Low 5 Register        |
| IOMMU_PMU_HIT_HIGH5_REG    | 0x028C | IOMMU PMU Hit High 5 Register       |
| IOMMU_PMU_ACCESS_LOW6_REG  | 0x0290 | IOMMU PMU Access Low 6 Register     |
| IOMMU_PMU_ACCESS_HIGH6_REG | 0x0294 | IOMMU PMU Access High 6 Register    |
| IOMMU_PMU_HIT_LOW6_REG     | 0x0298 | IOMMU PMU Hit Low 6 Register        |
| IOMMU_PMU_HIT_HIGH6_REG    | 0x029C | IOMMU PMU Hit High 6 Register       |
| IOMMU_PMU_ACCESS_LOW7_REG  | 0x02D0 | IOMMU PMU Access Low 7 Register     |
| IOMMU_PMU_ACCESS_HIGH7_REG | 0x02D4 | IOMMU PMU Access High 7 Register    |
| IOMMU_PMU_HIT_LOW7_REG     | 0x02D8 | IOMMU PMU Hit Low 7 Register        |
| IOMMU_PMU_HIT_HIGH7_REG    | 0x02DC | IOMMU PMU Hit High 7 Register       |
| IOMMU_PMU_ACCESS_LOW8_REG  | 0x02E0 | IOMMU PMU Access Low 8 Register     |
| IOMMU_PMU_ACCESS_HIGH8_REG | 0x02E4 | IOMMU PMU Access High 8 Register    |
| IOMMU_PMU_HIT_LOW8_REG     | 0x02E8 | IOMMU PMU Hit Low 8 Register        |
| IOMMU_PMU_HIT_HIGH8_REG    | 0x02EC | IOMMU PMU Hit High 8 Register       |
| IOMMU_PMU_TL_LOW0_REG      | 0x0300 | IOMMU Total Latency Low 0 Register  |
| IOMMU_PMU_TL_HIGH0_REG     | 0x0304 | IOMMU Total Latency High 0 Register |
| IOMMU_PMU_ML0_REG          | 0x0308 | IOMMU Max Latency 0 Register        |
| IOMMU_PMU_TL_LOW1_REG      | 0x0310 | IOMMU Total Latency Low 1 Register  |
| IOMMU_PMU_TL_HIGH1_REG     | 0x0314 | IOMMU Total Latency High 1 Register |
| IOMMU_PMU_ML1_REG          | 0x0318 | IOMMU Max Latency 1 Register        |
| IOMMU_PMU_TL_LOW2_REG      | 0x0320 | IOMMU Total Latency Low 2 Register  |
| IOMMU_PMU_TL_HIGH2_REG     | 0x0324 | IOMMU Total Latency High 2 Register |
| IOMMU_PMU_ML2_REG          | 0x0328 | IOMMU Max Latency 2 Register        |
| IOMMU_PMU_TL_LOW3_REG      | 0x0330 | IOMMU Total Latency Low 3 Register  |
| IOMMU_PMU_TL_HIGH3_REG     | 0x0334 | IOMMU Total Latency High 3 Register |
| IOMMU_PMU_ML3_REG          | 0x0338 | IOMMU Max Latency 3 Register        |
| IOMMU_PMU_TL_LOW4_REG      | 0x0340 | IOMMU Total Latency Low 4 Register  |
| IOMMU_PMU_TL_HIGH4_REG     | 0x0344 | IOMMU Total Latency High 4 Register |

| Register Name          | Offset | Description                         |
|------------------------|--------|-------------------------------------|
| IOMMU_PMU_ML4_REG      | 0x0348 | IOMMU Max Latency 4 Register        |
| IOMMU_PMU_TL_LOW5_REG  | 0x0350 | IOMMU Total Latency Low 5 Register  |
| IOMMU_PMU_TL_HIGH5_REG | 0x0354 | IOMMU Total Latency High 5 Register |
| IOMMU_PMU_ML5_REG      | 0x0358 | IOMMU Max Latency 5 Register        |
| IOMMU_PMU_TL_LOW6_REG  | 0x0360 | IOMMU Total Latency Low 6 Register  |
| IOMMU_PMU_TL_HIGH6_REG | 0x0364 | IOMMU Total Latency High 6 Register |
| IOMMU_PMU_ML6_REG      | 0x0368 | IOMMU Max Latency 6 Register        |

### 3.13.6 Register Description

#### 3.13.6.1 0x0010 IOMMU Reset Register (Default Value: 0x8003\_007F)

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x1         | <p>IOMMU_RESET<br/>IOMMU Software Reset Switch</p> <p>0: Set reset signal<br/>1: Release reset signal</p> <p>Before IOMMU software reset operation, ensure IOMMU never be opened; or all bus operations are completed; or DRAM and the peripherals have opened the corresponding switch, for shielding the effects of IOMMU reset.</p> |
| 30:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                      |
| 17             | R/W        | 0x1         | <p>PC_RST<br/>PTW Cache Reset</p> <p>PTW Cache address convert lane software reset switch.</p> <p>0: Set reset signal<br/>1: Release reset signal</p> <p>When PTW Cache occurs abnormal, the bit is used to reset PTW Cache individually.</p>                                                                                          |
| 16             | R/W        | 0x1         | <p>MTLB_RST<br/>MacroTlb Reset</p> <p>Macro TLB address convert lane software reset switch.</p> <p>0: Set reset signal<br/>1: Release reset signal</p> <p>When Macro TLB occurs abnormal, the bit is used to reset Macro TLB individually.</p>                                                                                         |

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                            |
| 15:7           | /          | /           | /                                                                                                                                                                                                                                                                      |
| 6              | R/W        | 0x1         | <p>M6_RST<br/>Master6 Reset<br/>Master6 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master6 occurs abnormal, the bit is used to reset Master6 individually.</p> <p><b>Note: This bit is not used.</b></p> |
| 5              | R/W        | 0x1         | <p>M5_RST<br/>Master5 Reset<br/>Master5 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master5 occurs abnormal, the bit is used to reset Master5 individually.</p>                                           |
| 4              | R/W        | 0x1         | <p>M4_RST<br/>Master4 Reset<br/>Master4 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master4 occurs abnormal, the bit is used to reset Master4 individually.</p>                                           |
| 3              | R/W        | 0x1         | <p>M3_RST<br/>Master3 Reset<br/>Master3 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master3 occurs abnormal, the bit is used to reset Master3 individually.</p>                                           |
| 2              | R/W        | 0x1         | <p>M2_RST<br/>Master2 Reset<br/>Master2 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master2 occurs abnormal, the bit is used to reset Master2 individually.</p>                                           |

| Offset: 0x0010 |            |             | Register Name: IOMMU_RESET_REG                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 1              | R/W        | 0x1         | <p>M1_RST<br/>Master1 Reset<br/>Master1 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master1 occurs abnormal, the bit is used to reset Master1 individually.</p> |
| 0              | R/W        | 0x1         | <p>M0_RST<br/>Master0 Reset<br/>Master0 address convert lane software reset switch.<br/>0: Set reset signal<br/>1: Release reset signal<br/>When Master0 occurs abnormal, the bit is used to reset Master0 individually.</p> |

### 3.13.6.2 0x0020 IOMMU Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: IOMMU_ENABLE_REG                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                            |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                      |
| 0              | R/W        | 0x0         | <p>ENABLE<br/>IOMMU module enable switch<br/>0: Disable IOMMU<br/>1: Enable IOMMU<br/>Before IOMMU address mapping function opens, configure the Translation Table Base register; or ensure all masters are in bypass status or no the status of sending bus demand(such as reset)</p> |

### 3.13.6.3 0x0030 IOMMU Bypass Register (Default Value: 0x0000\_007F)

| Offset: 0x0030 |            |             | Register Name: IOMMU_BYPASS_REG        |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:7           | /          | /           | /                                      |
| 6              | R/W        | 0x1         | <p>M6_BP<br/>Master6 bypass switch</p> |

| Offset: 0x0030 |            |             | Register Name: IOMMU_BYPASS_REG                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                              |
|                |            |             | <p>After bypass function is opened, IOMMU can not map the address of Master6 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> <p><b>Note: The bit is not used.</b></p>  |
| 5              | R/W        | 0x1         | <p>M5_BP</p> <p>Master5 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master5 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 4              | R/W        | 0x1         | <p>M4_BP</p> <p>Master4 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master4 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 3              | R/W        | 0x1         | <p>M3_BP</p> <p>Master3 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master3 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 2              | R/W        | 0x1         | <p>M2_BP</p> <p>Master2 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master2 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |
| 1              | R/W        | 0x1         | <p>M1_BP</p> <p>Master1 bypass switch</p>                                                                                                                                                                                                                                |

| Offset: 0x0030 |            |             | Register Name: IOMMU_BYPASS_REG                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                              |
|                |            |             | <p>After bypass function is opened, IOMMU can not map the address of Master1 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p>                                           |
| 0              | R/W        | 0x1         | <p>M0_BP</p> <p>Master0 bypass switch</p> <p>After bypass function is opened, IOMMU can not map the address of Master0 sending, and directly output the virtual address to MBUS as physical address.</p> <p>0: Disable bypass function<br/>1: Enable bypass function</p> |



#### NOTE

- Operating the register belongs to non-accurate timing sequence control function. That is, before the function is valid, master operation will complete address mapping function, and any subsequent operation will not perform address mapping.
- It is suggested that master is in reset state or in no any bus operation before operating the register.

#### 3.13.6.4 0x0040 IOMMU Auto Gating Register (Default Value: 0x0000\_0001)

| Offset: 0x0040 |            |             | Register Name: IOMMU_AUTO_GATING_REG                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:1           | /          | /           | /                                                                                                                                                                                                              |
| 0              | R/W        | 0x1         | <p>IOMMU_AUTO_GATING</p> <p>IOMMU circuit auto gating control</p> <p>The purpose is to decrease power consumption of the module.</p> <p>0: Disable auto gating function<br/>1: Enable auto gating function</p> |

### 3.13.6.5 0x0044 IOMMU Write Buffer Control Register (Default Value: 0x0000\_007F)

| Offset: 0x0044 |            |             | Register Name: IOMMU_WBUF_CTRL_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:7           | /          | /           | /                                  |
| 6              | R/W        | 0x1         | Reserved                           |
| 5              | R/W        | 0x1         | Reserved                           |
| 4              | R/W        | 0x1         | Reserved                           |
| 3              | R/W        | 0x1         | Reserved                           |
| 2              | R/W        | 0x1         | Reserved                           |
| 1              | R/W        | 0x1         | Reserved                           |
| 0              | R/W        | 0x1         | Reserved                           |

### 3.13.6.6 0x0048 IOMMU Out Of Order Control Register (Default Value: 0x0000\_007F)

| Offset: 0x0048 |            |             | Register Name: IOMMU_OOO_CTRL_REG                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:7           | /          | /           | /                                                                                                                                          |
| 6              | R/W        | 0x1         | M6_OOO_CTRL<br>Master6 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order<br><b>Note: This bit is not used.</b> |
| 5              | R/W        | 0x1         | M5_OOO_CTRL<br>Master5 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order                                       |
| 4              | R/W        | 0x1         | M4_OOO_CTRL<br>Master4 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order                                       |
| 3              | R/W        | 0x1         | M3_OOO_CTRL<br>Master3 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order                                       |
| 2              | R/W        | 0x1         | M2_OOO_CTRL<br>Master2 out-of-order control bit                                                                                            |

| Offset: 0x0048 |            |             | Register Name: IOMMU_OOO_CTRL_REG                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
|                |            |             | 0: Disable out-of-order<br>1: Enable out-of-order                                                    |
| 1              | R/W        | 0x1         | M1_OOO_CTRL<br>Master1 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |
| 0              | R/W        | 0x1         | M0_OOO_CTRL<br>Master0 out-of-order control bit<br>0: Disable out-of-order<br>1: Enable out-of-order |

### 3.13.6.7 0x004C IOMMU 4KB Boundary Protect Control Register (Default Value: 0x0000\_007F)



#### NOTE

When the virtual address sent by master is over the 4 KB boundary, 4 KB protection unit will split it into two serial access.

| Offset: 0x004C |            |             | Register Name: IOMMU_4KB_BDY_PRT_CTRL_REG                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31:7           | /          | /           | /                                                                                                                                                                             |
| 6              | R/W        | 0x1         | M6_4KB_BDY_PRT_CTRL<br>Master6 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect<br><b>Note: This bit is not used.</b> |
| 5              | R/W        | 0x1         | M5_4KB_BDY_PRT_CTRL<br>Master4 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect                                       |
| 4              | R/W        | 0x1         | M4_4KB_BDY_PRT_CTRL<br>Master4 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect                                                                          |

| Offset: 0x004C |            |             | Register Name: IOMMU_4KB_BDY_PRT_CTRL_REG                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
|                |            |             | 1: Enable 4 KB boundary protect                                                                                                         |
| 3              | R/W        | 0x1         | M3_4KB_BDY_PRT_CTRL<br>Master3 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 2              | R/W        | 0x1         | M2_4KB_BDY_PRT_CTRL<br>Master2 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 1              | R/W        | 0x1         | M1_4KB_BDY_PRT_CTRL<br>Master1 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |
| 0              | R/W        | 0x1         | M0_4KB_BDY_PRT_CTRL<br>Master0 4 KB boundary protect control bit<br>0: Disable 4 KB boundary protect<br>1: Enable 4 KB boundary protect |

### 3.13.6.8 0x0050 IOMMU Translation Table Base Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: IOMMU_TTB_REG                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                           |
| 31:14          | R/W        | 0x0         | TTB<br>Translation Table Base<br>Level1 page table starting address, aligned to 16 KB.<br>When operating the register, IOMMU address mapping function must be closed, namely IOMMU_ENABLE_REG is 0; Or Bypass function of all main equipment is set to 1, or no the state of transfer bus commands (such as setting). |
| 13:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                     |

**3.13.6.9 0x0060 IOMMU TLB Enable Register (Default Value: 0x0003\_007F)**

| Offset: 0x0060 |            |             | Register Name: IOMMU_TLB_ENABLE_REG                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:18          | /          | /           | /                                                                     |
| 17             | R/W        | 0x1         | PTW_CACHE_ENABLE<br>PTW Cache enable bit<br>0: Disable<br>1: Enable   |
| 16             | R/W        | 0x1         | MACRO_TLB_ENABLE<br>Macro TLB enable bit<br>0: Disable<br>1: Enable   |
| 15:7           | /          | /           | /                                                                     |
| 6              | R/W        | 0x1         | MICRO_TLB6_ENABLE<br>Micro TLB6 enable bit<br>0: Disable<br>1: Enable |
| 5              | R/W        | 0x1         | MICRO_TLB5_ENABLE<br>Micro TLB5 enable bit<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x1         | MICRO_TLB4_ENABLE<br>Micro TLB4 enable bit<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x1         | MICRO_TLB3_ENABLE<br>Micro TLB3 enable bit<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x1         | MICRO_TLB2_ENABLE<br>Micro TLB2 enable bit<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x1         | MICRO_TLB1_ENABLE<br>Micro TLB1 enable bit<br>0: Disable<br>1: Enable |

| Offset: 0x0060 |            |             | Register Name: IOMMU_TLB_ENABLE_REG                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 0              | R/W        | 0x1         | MICRO_TLBO_ENABLE<br>Micro TLBO enable bit<br>0: Disable<br>1: Enable |

### 3.13.6.10 0x0070 IOMMU TLB Prefetch Register (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG                                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:18          | /          | /           | /                                                                                                                                                                                                   |
| 17             | R/W        | 0x1         | PF_VL_PT_TO_PC<br>Prefetch Value Pagetable to PTW Cache<br>0: Disable<br>1: Enable<br>If the function is enabled, the prefetch function will not update the invalid Level1 page table to PTW cache. |
| 16             | R/W        | 0x1         | PF_VL_PT_TO_MT<br>Prefetch Value Pagetable to Macro TLB<br>0: Disable<br>1: Enable<br>If the function is enabled, the prefetch function will not update the invalid Level2 page table to Macro TLB. |
| 15:7           | /          | /           | /                                                                                                                                                                                                   |
| 6              | R/W        | 0x0         | MI_TLB6_PF<br>Micro TLB6 prefetch enable<br>0: Disable<br>1: Enable                                                                                                                                 |
| 5              | R/W        | 0x0         | MI_TLB5_PF<br>Micro TLB5 prefetch enable<br>0: Disable<br>1: Enable                                                                                                                                 |
| 4              | R/W        | 0x0         | MI_TLB4_PF<br>Micro TLB4 prefetch enable<br>0: Disable<br>1: Enable                                                                                                                                 |
| 3              | R/W        | 0x0         | MI_TLB3_PF                                                                                                                                                                                          |

| Offset: 0x0070 |            |             | Register Name: IOMMU_TLB_PREFETCH_REG                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
|                |            |             | <p>Micro TLB3 prefetch enable<br/>0: Disable<br/>1: Enable</p> <p><b>Note: If G2D accesses DDR, it is suggested that disable the prefetch function.</b></p> |
| 2              | R/W        | 0x0         | <p>MI_TLB2_PF<br/>Micro TLB2 prefetch enable<br/>0: Disable<br/>1: Enable</p>                                                                               |
| 1              | R/W        | 0x0         | <p>MI_TLB1_PF<br/>Micro TLB1 prefetch enable<br/>0: Disable<br/>1: Enable</p>                                                                               |
| 0              | R/W        | 0x0         | <p>MI_TLB0_PF<br/>Micro TLB0 prefetch enable<br/>0: Disable<br/>1: Enable</p>                                                                               |

### 3.13.6.11 0x0080 IOMMU TLB Flush Enable Register (Default Value: 0x0000\_0000)

When performing flush operations, all TLB/Cache access will be paused.

Before flush starts, the operation that has entered TLB continues to complete.

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:18          | /          | /           | /                                                                                                                                                                                                                         |
| 17             | R/WAC      | 0x0         | <p>PC_FS<br/>PTW Cache Flush<br/>Clear PTW Cache<br/>0: No clear operation or clear operation is completed<br/>1: Enable clear operation<br/>After the Flush operation is completed, the bit can clear automatically.</p> |
| 16             | R/WAC      | 0x0         | <p>MA_TLB_FS<br/>Macro TLB Flush<br/>Clear Macro TLB<br/>0: No clear operation or clear operation is completed</p>                                                                                                        |

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
|                |            |             | 1: Enable clear operation<br>After the Flush operation is completed, the bit can clear automatically.                                                                                                                |
| 15:7           | /          | /           | /                                                                                                                                                                                                                    |
| 6              | R/WAC      | 0x0         | MI_TLB6_FS<br>Micro TLB6 Flush<br>Clear Micro TLB6<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can clear automatically. |
| 5              | R/WAC      | 0x0         | MI_TLB5_FS<br>Micro TLB5 Flush<br>Clear Micro TLB5<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can clear automatically. |
| 4              | R/WAC      | 0x0         | MI_TLB4_FS<br>Micro TLB4 Flush<br>Clear Micro TLB4<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can clear automatically. |
| 3              | R/WAC      | 0x0         | MI_TLB3_FS<br>Micro TLB3 Flush<br>Clear Micro TLB3<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation<br>After the Flush operation is completed, the bit can clear automatically. |
| 2              | R/WAC      | 0x0         | MI_TLB2_FS<br>Micro TLB2 Flush<br>Clear Micro TLB2<br>0: No clear operation or clear operation is completed<br>1: Enable clear operation                                                                             |

| Offset: 0x0080 |            |             | Register Name: IOMMU_TLB_FLUSH_ENABLE_REG                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
|                |            |             | After the Flush operation is completed, the bit can clear automatically.                                                                                                                                                               |
| 1              | R/WAC      | 0x0         | <p>MI_TLB1_FS<br/>Micro TLB1 Flush<br/>Clear Micro TLB1</p> <p>0: No clear operation or clear operation is completed<br/>1: Enable clear operation</p> <p>After the Flush operation is completed, the bit can clear automatically.</p> |
| 0              | R/WAC      | 0x0         | <p>MI_TLB0_FS<br/>Micro TLB0 Flush<br/>Clear Micro TLB0</p> <p>0: No clear operation or clear operation is completed<br/>1: Enable clear operation</p> <p>After the Flush operation is completed, the bit can clear automatically.</p> |

### 3.13.6.12 0x0084 IOMMU TLB Invalidation Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: IOMMU_TLB_IVLD_MODE_SEL_REG                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:1           | /          | /           | /                                                                                                                              |
| 0              | R/W        | 0x0         | <p>TLB_IVLD_MODE_SEL</p> <p>0: Invalidate TLB by using the Mask mode<br/>1: Invalidate TLB by using the Start and End mode</p> |

### 3.13.6.13 0x0088 IOMMU TLB Invalidation Start Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: IOMMU_TLB_IVLD_STA_ADDR_REG                    |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:12          | R/W        | 0x0         | TLB_IVLD_STA_ADDR<br>TLB invalid start address, 4 KB aligned. |
| 11:0           | /          | /           | /                                                             |

### 3.13.6.14 0x008C IOMMU TLB Invalid End Address Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: IOMMU_TLB_IVLD_END_ADDR_REG                  |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:12          | R/W        | 0x0         | TLB_IVLD_END_ADDR<br>TLB invalid end address, 4 KB aligned. |
| 11:0           | /          | /           | /                                                           |

### 3.13.6.15 0x0090 IOMMU TLB Invalid Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: IOMMU_TLB_IVLD_ADDR_REG             |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:12          | R/W        | 0x0         | TLB_IVLD_ADDR<br>TLB invalid address, 4 KB aligned |
| 11:0           | /          | /           | /                                                  |

**Operation:**

- 1) Set the virtual address that needs to be operated in **IOMMU\_TLB\_IVLD\_ADDR\_REG**.
- 2) Set the mask of virtual address that needs to be operated in **IOMMU\_TLB\_IVLD\_ADDR\_MASK\_REG**.
- 3) Write '1' to **IOMMU\_TLB\_IVLD\_ENABLE\_REG[0]**.
- 4) Read **IOMMU\_TLB\_IVLD\_ENABLE\_REG[0]**, when it is '0', it indicates that invalidation behavior is finished.



**NOTE**

- When performing invalidation operation, TLB/Cache operation has not affected.
- After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation.

### 3.13.6.16 0x0094 IOMMU TLB Invalid Address Mask Register (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: IOMMU_TLB_IVLD_ADDR_MASK_REG                           |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:12          | R/W        | 0x0         | TLB_IVLD_ADDR_MASK<br>TLB invalid address mask register, 4 KB aligned |
| 11:0           | /          | /           | /                                                                     |

### 3.13.6.17 0x0098 IOMMU TLB Invalidation Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: IOMMU_TLB_IVLD_ENABLE_REG                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0              | R/WAC      | 0x0         | <p>TLB_IVLD_ENABLE<br/>Enable TLB invalidation operation<br/>0: No operation or operation is completed<br/>1: Enable invalidation operation<br/>After invalidation operation is completed, the bit can clear automatically.<br/>When operating invalidation operation, TLB/Cache operation has not affected.<br/>After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation.</p> |

### 3.13.6.18 0x009C IOMMU PC Invalidation Mode Select Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: IOMMU_PC_IVLD_MODE_SEL_REG                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31:1           | /          | /           | /                                                                                                                                                            |
| 0              | R/W        | 0x0         | <p>PC_IVLD_MODE_SEL<br/>PTW Cache Invalid Mode Select<br/>0: Invalidate PTW by using the Mask mode<br/>1: Invalidate PTW by using the Start and End mode</p> |

### 3.13.6.19 0x00A0 IOMMU PC Invalidation Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: IOMMU_PC_IVLD_ADDR_REG                    |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:20          | R/W        | 0x0         | PC_IVLD_ADDR<br>PTW Cache invalid address, 1 MB aligned. |
| 19:0           | /          | /           | /                                                        |

### 3.13.6.20 0x00A4 IOMMU PC Invalidation Start Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: IOMMU_PC_IVLD_STA_ADDR_REG                    |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:20          | R/W        | 0x0         | PC_IVLD_SA<br>PTW Cache invalid start address, 1 MB aligned. |
| 19:0           | /          | /           | /                                                            |

### 3.13.6.21 0x00A8 IOMMU PC Invalidation Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x00A8 |            |             | Register Name: IOMMU_PC_IVLD_ENABLE_REG                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                         |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                   |
| 0              | R/WAC      | 0x0         | PC_IVLD_ENABLE<br>Enable PTW Cache invalidation operation<br>0: No operation or operation is completed<br>1: Enable invalidation operation<br>After invalidation operation is completed, the bit can clear automatically.<br>After or before invalidation operation starts, there is no absolute relationship between the same address switch operation and invalidation operation. |

### 3.13.6.22 0x00AC IOMMU PC Invalidation End Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00AC |            |             | Register Name: IOMMU_PC_IVLD_END_ADDR_REG                  |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:20          | R/W        | 0x0         | PC_IVLD_EA<br>PTW Cache invalid end address, 1 MB aligned. |
| 19:0           | /          | /           | /                                                          |

### 3.13.6.23 0x00B0 IOMMU Domain Authority Control 0 Register (Default Value: 0x0000\_0000)

Software can set 15 different permission control types in IOMMU\_DM\_AUT\_CTRL\_REG0~7. A default access control type is DOMAIN0. The read/write operation of DOMAIN1~15 is unlimited by default.

Software needs to set the index of the permission control domain corresponding to the page table item in the bit[7:4] of the Level2 page table, the default value is 0 (use domian0), that is, the read/write operation is not controlled.

Setting REG\_ARD\_OVWT can mask the Domain control defined by IOMMU\_DM\_AUT\_CTRL\_REG0–7. All Level2 page table type are covered by the type of REG\_ARD\_OVWT. The read/write operation is permitted by default.

| Offset: 0x00B0 |            |             | Register Name: IOMMU_DM_AUT_CTRL0_REG                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:30          | /          | /           | /                                                                                                                                                                                                    |
| 29             | R/W        | 0x0         | <p>DM1_M6_WT_AUT_CTRL<br/>Domain1 write permission control for master6<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p> |
| 28             | R/W        | 0x0         | <p>DM1_M6_RD_AUT_CTRL<br/>Domain1 read permission control for master6<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p>    |
| 27             | R/W        | 0x0         | <p>DM1_M5_WT_AUT_CTRL<br/>Domain1 write permission control for master5<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 26             | R/W        | 0x0         | <p>DM1_M5_RD_AUT_CTRL<br/>Domain1 read permission control for master5<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                             |
| 25             | R/W        | 0x0         | <p>DM1_M4_WT_AUT_CTRL<br/>Domain1 write permission control for master4<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 24             | R/W        | 0x0         | <p>DM1_M4_RD_AUT_CTRL<br/>Domain1 read permission control for master4<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                             |
| 23             | R/W        | 0x0         | <p>DM1_M3_WT_AUT_CTRL<br/>Domain1 write permission control for master3<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 22             | R/W        | 0x0         | DM1_M3_RD_AUT_CTRL                                                                                                                                                                                   |

| Offset: 0x00B0 |            |             | Register Name: IOMMU_DM_AUT_CTRL0_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
|                |            |             | Domain1 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                                               |
| 21             | R/W        | 0x0         | DM1_M2_WT_AUT_CTRL<br>Domain1 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 20             | R/W        | 0x0         | DM1_M2_RD_AUT_CTRL<br>Domain1 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 19             | R/W        | 0x0         | DM1_M1_WT_AUT_CTRL<br>Domain1 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 18             | R/W        | 0x0         | DM1_M1_RD_AUT_CTRL<br>Domain1 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 17             | R/W        | 0x0         | DM1_M0_WT_AUT_CTRL<br>Domain1 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 16             | R/W        | 0x0         | DM1_M0_RD_AUT_CTRL<br>Domain1 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                      |
| 13             | R          | 0x0         | DM0_M6_WT_AUT_CTRL<br>Domain0 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R          | 0x0         | DM0_M6_RD_AUT_CTRL<br>Domain0 read permission control for master6<br>0: The read-operation is permitted                                                                                |

| Offset: 0x00B0 |            |             | Register Name: IOMMU_DM_AUT_CTRL0_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | 1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>                                                                          |
| 11             | R          | 0x0         | DM0_M5_WT_AUT_CTRL<br>Domain0 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10             | R          | 0x0         | DM0_M5_RD_AUT_CTRL<br>Domain0 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9              | R          | 0x0         | DM0_M4_WT_AUT_CTRL<br>Domain0 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8              | R          | 0x0         | DM0_M4_RD_AUT_CTRL<br>Domain0 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R          | 0x0         | DM0_M3_WT_AUT_CTRL<br>Domain0 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R          | 0x0         | DM0_M3_RD_AUT_CTRL<br>Domain0 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R          | 0x0         | DM0_M2_WT_AUT_CTRL<br>Domain0 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R          | 0x0         | DM0_M2_RD_AUT_CTRL<br>Domain0 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R          | 0x0         | DM0_M1_WT_AUT_CTRL<br>Domain0 write permission control for master1                                                                                |

| Offset: 0x00B0 |            |             | Register Name: IOMMU_DM_AUT_CTRL0_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | 0: The write-operation is permitted<br>1: The write-operation is prohibited                                                                       |
| 2              | R          | 0x0         | DM0_M1_RD_AUT_CTRL<br>Domain0 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R          | 0x0         | DM0_M0_WT_AUT_CTRL<br>Domain0 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R          | 0x0         | DM0_M0_RD_AUT_CTRL<br>Domain0 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.13.6.24 0x00B4 IOMMU Domain Authority Control 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: IOMMU_DM_AUT_CTRL1_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:30          | /          | /           | /                                                                                                                                                                                      |
| 29             | R/W        | 0x0         | DM3_M6_WT_AUT_CTRL<br>Domain3 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 28             | R/W        | 0x0         | DM3_M6_RD_AUT_CTRL<br>Domain3 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 27             | R/W        | 0x0         | DM3_M5_WT_AUT_CTRL<br>Domain3 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 26             | R/W        | 0x0         | DM3_M5_RD_AUT_CTRL<br>Domain3 read permission control for master5                                                                                                                      |

| Offset: 0x00B4 |            |             | Register Name: IOMMU_DM_AUT_CTRL1_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | 0: The read-operation is permitted<br>1: The read-operation is prohibited                                                                         |
| 25             | R/W        | 0x0         | DM3_M4_WT_AUT_CTRL<br>Domain3 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24             | R/W        | 0x0         | DM3_M4_RD_AUT_CTRL<br>Domain3 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM3_M3_WT_AUT_CTRL<br>Domain3 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM3_M3_RD_AUT_CTRL<br>Domain3 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM3_M2_WT_AUT_CTRL<br>Domain3 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20             | R/W        | 0x0         | DM3_M2_RD_AUT_CTRL<br>Domain3 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19             | R/W        | 0x0         | DM3_M1_WT_AUT_CTRL<br>Domain3 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18             | R/W        | 0x0         | DM3_M1_RD_AUT_CTRL<br>Domain3 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17             | R/W        | 0x0         | DM3_M0_WT_AUT_CTRL<br>Domain3 write permission control for master0                                                                                |

| Offset: 0x00B4 |            |             | Register Name: IOMMU_DM_AUT_CTRL1_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
|                |            |             | 0: The write-operation is permitted<br>1: The write-operation is prohibited                                                                                                            |
| 16             | R/W        | 0x0         | DM3_M0_RD_AUT_CTRL<br>Domain3 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                      |
| 13             | R/W        | 0x0         | DM2_M6_WT_AUT_CTRL<br>Domain2 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R/W        | 0x0         | DM2_M6_RD_AUT_CTRL<br>Domain2 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 11             | R/W        | 0x0         | DM2_M5_WT_AUT_CTRL<br>Domain2 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 10             | R/W        | 0x0         | DM2_M5_RD_AUT_CTRL<br>Domain2 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 9              | R/W        | 0x0         | DM2_M4_WT_AUT_CTRL<br>Domain2 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 8              | R/W        | 0x0         | DM2_M4_RD_AUT_CTRL<br>Domain2 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 7              | R/W        | 0x0         | DM2_M3_WT_AUT_CTRL<br>Domain2 write permission control for master3<br>0: The write-operation is permitted                                                                              |

| Offset: 0x00B4 |            |             | Register Name: IOMMU_DM_AUT_CTRL1_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | 1: The write-operation is prohibited                                                                                                              |
| 6              | R/W        | 0x0         | DM2_M3_RD_AUT_CTRL<br>Domain2 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | DM2_M2_WT_AUT_CTRL<br>Domain2 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM2_M2_RD_AUT_CTRL<br>Domain2 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM2_M1_WT_AUT_CTRL<br>Domain2 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM2_M1_RD_AUT_CTRL<br>Domain2 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM2_M0_WT_AUT_CTRL<br>Domain2 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM2_M0_RD_AUT_CTRL<br>Domain2 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.13.6.25 0x00B8 IOMMU Domain Authority Control 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL2_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:30          | /          | /           | /                                     |
| 29             | R/W        | 0x0         | DM5_M6_WT_AUT_CTRL                    |

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL2_REG                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
|                |            |             | <p>Domain5 write permission control for master6</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p>                        |
| 28             | R/W        | 0x0         | <p>DM5_M6_RD_AUT_CTRL</p> <p>Domain5 read permission control for master6</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p> |
| 27             | R/W        | 0x0         | <p>DM5_M5_WT_AUT_CTRL</p> <p>Domain5 write permission control for master5</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 26             | R/W        | 0x0         | <p>DM5_M5_RD_AUT_CTRL</p> <p>Domain5 read permission control for master5</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 25             | R/W        | 0x0         | <p>DM5_M4_WT_AUT_CTRL</p> <p>Domain5 write permission control for master4</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 24             | R/W        | 0x0         | <p>DM5_M4_RD_AUT_CTRL</p> <p>Domain5 read permission control for master4</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 23             | R/W        | 0x0         | <p>DM5_M3_WT_AUT_CTRL</p> <p>Domain5 write permission control for master3</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 22             | R/W        | 0x0         | <p>DM5_M3_RD_AUT_CTRL</p> <p>Domain5 read permission control for master3</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 21             | R/W        | 0x0         | <p>DM5_M2_WT_AUT_CTRL</p> <p>Domain5 write permission control for master2</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL2_REG                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 20             | R/W        | 0x0         | <p>DM5_M2_RD_AUT_CTRL<br/>Domain5 read permission control for master2<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 19             | R/W        | 0x0         | <p>DM5_M1_WT_AUT_CTRL<br/>Domain5 write permission control for master1<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 18             | R/W        | 0x0         | <p>DM5_M1_RD_AUT_CTRL<br/>Domain5 read permission control for master1<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 17             | R/W        | 0x0         | <p>DM5_M0_WT_AUT_CTRL<br/>Domain5 write permission control for master0<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 16             | R/W        | 0x0         | <p>DM5_M0_RD_AUT_CTRL<br/>Domain5 read permission control for master0<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                          |
| 15:14          | /          | /           | /                                                                                                                                                                                                 |
| 13             | R/W        | 0x0         | <p>DM4_M6_WT_AUT_CTRL<br/>Domain4 write permission control for master6<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited<br/><b>Note: The bit is not used.</b></p> |
| 12             | R/W        | 0x0         | <p>DM4_M6_RD_AUT_CTRL<br/>Domain4 read permission control for master6<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited<br/><b>Note: The bit is not used.</b></p>    |
| 11             | R/W        | 0x0         | <p>DM4_M5_WT_AUT_CTRL<br/>Domain4 write permission control for master5<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                       |
| 10             | R/W        | 0x0         | DM4_M5_RD_AUT_CTRL                                                                                                                                                                                |

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL2_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | Domain4 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                          |
| 9              | R/W        | 0x0         | DM4_M4_WT_AUT_CTRL<br>Domain4 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8              | R/W        | 0x0         | DM4_M4_RD_AUT_CTRL<br>Domain4 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | DM4_M3_WT_AUT_CTRL<br>Domain4 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | DM4_M3_RD_AUT_CTRL<br>Domain4 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | DM4_M2_WT_AUT_CTRL<br>Domain4 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM4_M2_RD_AUT_CTRL<br>Domain4 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM4_M1_WT_AUT_CTRL<br>Domain4 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM4_M1_RD_AUT_CTRL<br>Domain4 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM4_M0_WT_AUT_CTRL                                                                                                                                |

| Offset: 0x00B8 |            |             | Register Name: IOMMU_DM_AUT_CTRL2_REG                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
|                |            |             | Domain4 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                    |
| 0              | R/W        | 0x0         | DM4_M0_RD_AUT_CTRL<br>Domain4 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited |

### 3.13.6.26 0x00BC IOMMU Domain Authority Control 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x00BC |            |             | Register Name: IOMMU_DM_AUT_CTRL3_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:30          | /          | /           | /                                                                                                                                                                                      |
| 29             | R/W        | 0x0         | DM7_M6_WT_AUT_CTRL<br>Domain7 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 28             | R/W        | 0x0         | DM7_M6_RD_AUT_CTRL<br>Domain7 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 27             | R/W        | 0x0         | DM7_M5_WT_AUT_CTRL<br>Domain7 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 26             | R/W        | 0x0         | DM7_M5_RD_AUT_CTRL<br>Domain7 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 25             | R/W        | 0x0         | DM7_M4_WT_AUT_CTRL<br>Domain7 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 24             | R/W        | 0x0         | DM7_M4_RD_AUT_CTRL                                                                                                                                                                     |

| Offset: 0x00BC |            |             | Register Name: IOMMU_DM_AUT_CTRL3_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | Domain7 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                          |
| 23             | R/W        | 0x0         | DM7_M3_WT_AUT_CTRL<br>Domain7 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM7_M3_RD_AUT_CTRL<br>Domain7 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM7_M2_WT_AUT_CTRL<br>Domain7 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20             | R/W        | 0x0         | DM7_M2_RD_AUT_CTRL<br>Domain7 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19             | R/W        | 0x0         | DM7_M1_WT_AUT_CTRL<br>Domain7 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18             | R/W        | 0x0         | DM7_M1_RD_AUT_CTRL<br>Domain7 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17             | R/W        | 0x0         | DM7_M0_WT_AUT_CTRL<br>Domain7 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16             | R/W        | 0x0         | DM7_M0_RD_AUT_CTRL<br>Domain7 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 15:14          | /          | /           | /                                                                                                                                                 |

| Offset: 0x00BC |            |             | Register Name: IOMMU_DM_AUT_CTRL3_REG                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 13             | R/W        | 0x0         | <p>DM6_M6_WT_AUT_CTRL<br/>Domain6 write permission control for master6<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p> |
| 12             | R/W        | 0x0         | <p>DM6_M6_RD_AUT_CTRL<br/>Domain6 read permission control for master6<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p> <p><b>Note: The bit is not used.</b></p>    |
| 11             | R/W        | 0x0         | <p>DM6_M5_WT_AUT_CTRL<br/>Domain6 write permission control for master5<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 10             | R/W        | 0x0         | <p>DM6_M5_RD_AUT_CTRL<br/>Domain6 read permission control for master5<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                             |
| 9              | R/W        | 0x0         | <p>DM6_M4_WT_AUT_CTRL<br/>Domain6 write permission control for master4<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 8              | R/W        | 0x0         | <p>DM6_M4_RD_AUT_CTRL<br/>Domain6 read permission control for master4<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                             |
| 7              | R/W        | 0x0         | <p>DM6_M3_WT_AUT_CTRL<br/>Domain6 write permission control for master3<br/>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>                                          |
| 6              | R/W        | 0x0         | <p>DM6_M3_RD_AUT_CTRL<br/>Domain6 read permission control for master3<br/>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>                                             |
| 5              | R/W        | 0x0         | <p>DM6_M2_WT_AUT_CTRL<br/>Domain6 write permission control for master2<br/>0: The write-operation is permitted</p>                                                                                   |

| Offset: 0x00BC |            |             | Register Name: IOMMU_DM_AUT_CTRL3_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | 1: The write-operation is prohibited                                                                                                              |
| 4              | R/W        | 0x0         | DM6_M2_RD_AUT_CTRL<br>Domain6 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM6_M1_WT_AUT_CTRL<br>Domain6 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM6_M1_RD_AUT_CTRL<br>Domain6 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM6_M0_WT_AUT_CTRL<br>Domain6 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM6_M0_RD_AUT_CTRL<br>Domain6 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.13.6.27 0x00C0 IOMMU Domain Authority Control 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: IOMMU_DM_AUT_CTRL4_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:30          | /          | /           | /                                                                                                                                                                                      |
| 29             | R/W        | 0x0         | DM9_M6_WT_AUT_CTRL<br>Domain9 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 28             | R/W        | 0x0         | DM9_M6_RD_AUT_CTRL<br>Domain9 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |

| Offset: 0x00C0 |            |             | Register Name: IOMMU_DM_AUT_CTRL4_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
|                |            |             | <b>Note: The bit is not used.</b>                                                                                                                 |
| 27             | R/W        | 0x0         | DM9_M5_WT_AUT_CTRL<br>Domain9 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM9_M5_RD_AUT_CTRL<br>Domain9 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM9_M4_WT_AUT_CTRL<br>Domain9 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 24             | R/W        | 0x0         | DM9_M4_RD_AUT_CTRL<br>Domain9 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM9_M3_WT_AUT_CTRL<br>Domain9 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM9_M3_RD_AUT_CTRL<br>Domain9 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM9_M2_WT_AUT_CTRL<br>Domain9 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20             | R/W        | 0x0         | DM9_M2_RD_AUT_CTRL<br>Domain9 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19             | R/W        | 0x0         | DM9_M1_WT_AUT_CTRL<br>Domain9 write permission control for master1<br>0: The write-operation is permitted                                         |

| Offset: 0x00C0 |            |             | Register Name: IOMMU_DM_AUT_CTRL4_REG                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
|                |            |             | 1: The write-operation is prohibited                                                                                                                                                   |
| 18             | R/W        | 0x0         | DM9_M1_RD_AUT_CTRL<br>Domain9 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 17             | R/W        | 0x0         | DM9_M0_WT_AUT_CTRL<br>Domain9 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 16             | R/W        | 0x0         | DM9_M0_RD_AUT_CTRL<br>Domain9 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                      |
| 13             | R/W        | 0x0         | DM8_M6_WT_AUT_CTRL<br>Domain8 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R/W        | 0x0         | DM8_M6_RD_AUT_CTRL<br>Domain8 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 11             | R/W        | 0x0         | DM8_M5_WT_AUT_CTRL<br>Domain8 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 10             | R/W        | 0x0         | DM8_M5_RD_AUT_CTRL<br>Domain8 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 9              | R/W        | 0x0         | DM8_M4_WT_AUT_CTRL<br>Domain8 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |

| Offset: 0x00C0 |            |             | Register Name: IOMMU_DM_AUT_CTRL4_REG                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 8              | R/W        | 0x0         | DM8_M4_RD_AUT_CTRL<br>Domain8 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | DM8_M3_WT_AUT_CTRL<br>Domain8 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | DM8_M3_RD_AUT_CTRL<br>Domain8 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | DM8_M2_WT_AUT_CTRL<br>Domain8 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM8_M2_RD_AUT_CTRL<br>Domain8 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM8_M1_WT_AUT_CTRL<br>Domain8 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM8_M1_RD_AUT_CTRL<br>Domain8 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM8_M0_WT_AUT_CTRL<br>Domain8 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM8_M0_RD_AUT_CTRL<br>Domain8 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

## 3.13.6.28 0x00C4 IOMMU Domain Authority Control 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: IOMMU_DM_AUT_CTRL5_REG                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:30          | /          | /           | /                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | DM11_M6_WT_AUT_CTRL<br>Domain11 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 28             | R/W        | 0x0         | DM11_M6_RD_AUT_CTRL<br>Domain11 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 27             | R/W        | 0x0         | DM11_M5_WT_AUT_CTRL<br>Domain11 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 26             | R/W        | 0x0         | DM11_M5_RD_AUT_CTRL<br>Domain11 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 25             | R/W        | 0x0         | DM11_M4_WT_AUT_CTRL<br>Domain11 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 24             | R/W        | 0x0         | DM11_M4_RD_AUT_CTRL<br>Domain11 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 23             | R/W        | 0x0         | DM11_M3_WT_AUT_CTRL<br>Domain11 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 22             | R/W        | 0x0         | DM11_M3_RD_AUT_CTRL<br>Domain11 read permission control for master3                                                                                                                      |

| Offset: 0x00C4 |            |             | Register Name: IOMMU_DM_AUT_CTRL5_REG                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
|                |            |             | 0: The read-operation is permitted<br>1: The read-operation is prohibited                                                                                                                |
| 21             | R/W        | 0x0         | DM11_M2_WT_AUT_CTRL<br>Domain11 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 20             | R/W        | 0x0         | DM11_M2_RD_AUT_CTRL<br>Domain11 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 19             | R/W        | 0x0         | DM11_M1_WT_AUT_CTRL<br>Domain11 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 18             | R/W        | 0x0         | DM11_M1_RD_AUT_CTRL<br>Domain11 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 17             | R/W        | 0x0         | DM11_M0_WT_AUT_CTRL<br>Domain11 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 16             | R/W        | 0x0         | DM11_M0_RD_AUT_CTRL<br>Domain11 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                        |
| 13             | R/W        | 0x0         | DM10_M6_WT_AUT_CTRL<br>Domain10 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R/W        | 0x0         | DM10_M6_RD_AUT_CTRL<br>Domain10 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |

| Offset: 0x00C4 |            |             | Register Name: IOMMU_DM_AUT_CTRL5_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
|                |            |             | <b>Note: The bit is not used.</b>                                                                                                                   |
| 11             | R/W        | 0x0         | DM10_M5_WT_AUT_CTRL<br>Domain10 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10             | R/W        | 0x0         | DM10_M5_RD_AUT_CTRL<br>Domain10 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9              | R/W        | 0x0         | DM10_M4_WT_AUT_CTRL<br>Domain10 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8              | R/W        | 0x0         | DM10_M4_RD_AUT_CTRL<br>Domain10 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | DM10_M3_WT_AUT_CTRL<br>Domain10 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | DM10_M3_RD_AUT_CTRL<br>Domain10 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | DM10_M2_WT_AUT_CTRL<br>Domain10 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM10_M2_RD_AUT_CTRL<br>Domain10 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM10_M1_WT_AUT_CTRL<br>Domain10 write permission control for master1<br>0: The write-operation is permitted                                         |

| Offset: 0x00C4 |            |             | Register Name: IOMMU_DM_AUT_CTRL5_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
|                |            |             | 1: The write-operation is prohibited                                                                                                                |
| 2              | R/W        | 0x0         | DM10_M1_RD_AUT_CTRL<br>Domain10 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM10_M0_WT_AUT_CTRL<br>Domain10 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM10_M0_RD_AUT_CTRL<br>Domain10 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.13.6.29 0x00C8 IOMMU Domain Authority Control 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: IOMMU_DM_AUT_CTRL6_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                   |
| 29             | R/W        | 0x0         | DM13_M6_WT_AUT_CTRL<br>Domain13 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 28             | R/W        | 0x0         | DM13_M6_RD_AUT_CTRL<br>Domain13 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 27             | R/W        | 0x0         | DM13_M5_WT_AUT_CTRL<br>Domain13 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 26             | R/W        | 0x0         | DM13_M5_RD_AUT_CTRL<br>Domain13 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 25             | R/W        | 0x0         | DM13_M4_WT_AUT_CTRL                                                                                                                                 |

| Offset: 0x00C8 |            |             | Register Name: IOMMU_DM_AUT_CTRL6_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
|                |            |             | Domain13 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                        |
| 24             | R/W        | 0x0         | DM13_M4_RD_AUT_CTRL<br>Domain13 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 23             | R/W        | 0x0         | DM13_M3_WT_AUT_CTRL<br>Domain13 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 22             | R/W        | 0x0         | DM13_M3_RD_AUT_CTRL<br>Domain13 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 21             | R/W        | 0x0         | DM13_M2_WT_AUT_CTRL<br>Domain13 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 20             | R/W        | 0x0         | DM13_M2_RD_AUT_CTRL<br>Domain13 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 19             | R/W        | 0x0         | DM13_M1_WT_AUT_CTRL<br>Domain13 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 18             | R/W        | 0x0         | DM13_M1_RD_AUT_CTRL<br>Domain13 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 17             | R/W        | 0x0         | DM13_M0_WT_AUT_CTRL<br>Domain13 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 16             | R/W        | 0x0         | DM13_M0_RD_AUT_CTRL                                                                                                                                 |

| Offset: 0x00C8 |            |             | Register Name: IOMMU_DM_AUT_CTRL6_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
|                |            |             | Domain13 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                           |
| 15:14          | /          | /           | /                                                                                                                                                   |
| 13             | R/W        | 0x0         | DM12_M6_WT_AUT_CTRL<br>Domain12 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 12             | R/W        | 0x0         | DM12_M6_RD_AUT_CTRL<br>Domain12 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 11             | R/W        | 0x0         | DM12_M5_WT_AUT_CTRL<br>Domain12 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 10             | R/W        | 0x0         | DM12_M5_RD_AUT_CTRL<br>Domain12 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 9              | R/W        | 0x0         | DM12_M4_WT_AUT_CTRL<br>Domain12 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 8              | R/W        | 0x0         | DM12_M4_RD_AUT_CTRL<br>Domain12 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | DM12_M3_WT_AUT_CTRL<br>Domain12 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | DM12_M3_RD_AUT_CTRL<br>Domain12 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

| Offset: 0x00C8 |            |             | Register Name: IOMMU_DM_AUT_CTRL6_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 5              | R/W        | 0x0         | DM12_M2_WT_AUT_CTRL<br>Domain12 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM12_M2_RD_AUT_CTRL<br>Domain12 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM12_M1_WT_AUT_CTRL<br>Domain12 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM12_M1_RD_AUT_CTRL<br>Domain12 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM12_M0_WT_AUT_CTRL<br>Domain12 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM12_M0_RD_AUT_CTRL<br>Domain12 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |

### 3.13.6.30 0x00CC IOMMU Domain Authority Control 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL7_REG                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:30          | /          | /           | /                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | DM15_M6_WT_AUT_CTRL<br>Domain15 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 28             | R/W        | 0x0         | DM15_M6_RD_AUT_CTRL                                                                                                                                                                      |

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL7_REG                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
|                |            |             | <p>Domain15 read permission control for master6</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p> <p><b>Note:</b> The bit is not used.</p> |
| 27             | R/W        | 0x0         | <p>DM15_M5_WT_AUT_CTRL</p> <p>Domain15 write permission control for master5</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>            |
| 26             | R/W        | 0x0         | <p>DM15_M5_RD_AUT_CTRL</p> <p>Domain15 read permission control for master5</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>               |
| 25             | R/W        | 0x0         | <p>DM15_M4_WT_AUT_CTRL</p> <p>Domain15 write permission control for master4</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>            |
| 24             | R/W        | 0x0         | <p>DM15_M4_RD_AUT_CTRL</p> <p>Domain15 read permission control for master4</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>               |
| 23             | R/W        | 0x0         | <p>DM15_M3_WT_AUT_CTRL</p> <p>Domain15 write permission control for master3</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>            |
| 22             | R/W        | 0x0         | <p>DM15_M3_RD_AUT_CTRL</p> <p>Domain15 read permission control for master3</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>               |
| 21             | R/W        | 0x0         | <p>DM15_M2_WT_AUT_CTRL</p> <p>Domain15 write permission control for master2</p> <p>0: The write-operation is permitted<br/>1: The write-operation is prohibited</p>            |
| 20             | R/W        | 0x0         | <p>DM15_M2_RD_AUT_CTRL</p> <p>Domain15 read permission control for master2</p> <p>0: The read-operation is permitted<br/>1: The read-operation is prohibited</p>               |

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL7_REG                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 19             | R/W        | 0x0         | DM15_M1_WT_AUT_CTRL<br>Domain15 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 18             | R/W        | 0x0         | DM15_M1_RD_AUT_CTRL<br>Domain15 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 17             | R/W        | 0x0         | DM15_M0_WT_AUT_CTRL<br>Domain15 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 16             | R/W        | 0x0         | DM15_M0_RD_AUT_CTRL<br>Domain15 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                        |
| 13             | R/W        | 0x0         | DM14_M6_WT_AUT_CTRL<br>Domain14 write permission control for master6<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R/W        | 0x0         | DM14_M6_RD_AUT_CTRL<br>Domain14 read permission control for master6<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 11             | R/W        | 0x0         | DM14_M5_WT_AUT_CTRL<br>Domain14 write permission control for master5<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 10             | R/W        | 0x0         | DM14_M5_RD_AUT_CTRL<br>Domain14 read permission control for master5<br>0: The read-operation is permitted<br>1: The read-operation is prohibited                                         |
| 9              | R/W        | 0x0         | DM14_M4_WT_AUT_CTRL                                                                                                                                                                      |

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL7_REG                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
|                |            |             | Domain14 write permission control for master4<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                        |
| 8              | R/W        | 0x0         | DM14_M4_RD_AUT_CTRL<br>Domain14 read permission control for master4<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | DM14_M3_WT_AUT_CTRL<br>Domain14 write permission control for master3<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | DM14_M3_RD_AUT_CTRL<br>Domain14 read permission control for master3<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | DM14_M2_WT_AUT_CTRL<br>Domain14 write permission control for master2<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | DM14_M2_RD_AUT_CTRL<br>Domain14 read permission control for master2<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | DM14_M1_WT_AUT_CTRL<br>Domain14 write permission control for master1<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | DM14_M1_RD_AUT_CTRL<br>Domain14 read permission control for master1<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | DM14_M0_WT_AUT_CTRL<br>Domain14 write permission control for master0<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | DM14_M0_RD_AUT_CTRL                                                                                                                                 |

| Offset: 0x00CC |            |             | Register Name: IOMMU_DM_AUT_CTRL7_REG                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
|                |            |             | Domain14 read permission control for master0<br>0: The read-operation is permitted<br>1: The read-operation is prohibited |

### 3.13.6.31 0x00D0 IOMMU Domain Authority Overwrite Register (Default Value: 0x0000\_0000)

Setting the REG\_ARD\_OVWT can mask the Domain control defined by IOMMU\_DM\_AUT\_CTRL\_REG0–7. All the property of Level2 are covered by the property defined in REG\_ARD\_OVWT. Allow read and write for all by default.

| Offset: 0x00D0 |            |             | Register Name: IOMMU_DM_AUT_OVWT_REG                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31             | R/W        | 0x0         | DM_AUT_OVWT_ENABLE<br>Domain write/read permission overwrite enable<br>0: Disable<br>1: Enable                                                                                        |
| 30:14          | /          | /           | /                                                                                                                                                                                     |
| 13             | R/W        | 0x0         | M6_WT_AUT_OVWT_CTRL<br>Master6 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited<br><b>Note: The bit is not used.</b> |
| 12             | R/W        | 0x0         | M6_RD_AUT_OVWT_CTRL<br>Master6 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited<br><b>Note: The bit is not used.</b>    |
| 11             | R/W        | 0x0         | M5_WT_AUT_OVWT_CTRL<br>Master5 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited                                      |
| 10             | R/W        | 0x0         | M5_RD_AUT_OVWT_CTRL<br>Master5 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read operation is prohibited                                         |
| 9              | R/W        | 0x0         | M4_WT_AUT_OVWT_CTRL<br>Master5 write permission overwrite control                                                                                                                     |

| Offset: 0x00D0 |            |             | Register Name: IOMMU_DM_AUT_OVWT_REG                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
|                |            |             | 0: The write-operation is permitted<br>1: The write-operation is prohibited                                                                      |
| 8              | R/W        | 0x0         | M4_RD_AUT_OVWT_CTRL<br>Master5 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 7              | R/W        | 0x0         | M3_WT_AUT_OVWT_CTRL<br>Master3 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 6              | R/W        | 0x0         | M3_RD_AUT_OVWT_CTRL<br>Master3 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 5              | R/W        | 0x0         | M2_WT_AUT_OVWT_CTRL<br>Master2 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 4              | R/W        | 0x0         | M2_RD_AUT_OVWT_CTRL<br>Master2 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 3              | R/W        | 0x0         | M1_WT_AUT_OVWT_CTRL<br>Master1 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 2              | R/W        | 0x0         | M1_RD_AUT_OVWT_CTRL<br>Master1 read permission overwrite control<br>0: The read-operation is permitted<br>1: The read-operation is prohibited    |
| 1              | R/W        | 0x0         | M0_WT_AUT_OVWT_CTRL<br>Master0 write permission overwrite control<br>0: The write-operation is permitted<br>1: The write-operation is prohibited |
| 0              | R/W        | 0x0         | M0_RD_AUT_OVWT_CTRL<br>Master0 read permission overwrite control                                                                                 |

| Offset: 0x00D0 |            |             | Register Name: IOMMU_DM_AUT_OVWT_REG                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
|                |            |             | 0: The read-operation is permitted<br>1: The read-operation is prohibited |

### 3.13.6.32 0x0100 IOMMU Interrupt Enable Register (Default Value: 0x0000\_0000)

Invalid page table and permission error can not make one device or multi-devices in system work normally.

Permission error usually happens in MicroTLB. The error generates interrupt and waits for processing through software.

Invalid page table usually happens in MacroTLB. The error can not influence the access of other devices. So the error page table needs go back the way it comes, but the error should not be written in each level TLB.

| Offset: 0x0100 |            |             | Register Name: IOMMU_INT_ENABLE_REG                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:21          | /          | /           | /                                                                                                                                  |
| 20             | R/W        | 0x0         | DBG_PF_L2_IV_PT_EN.<br>Debug or Prefetch Invalid Page Table Enable<br>0: Mask interrupt<br>1: Enable interrupt                     |
| 19             | R/W        | 0x0         | DBG_PF_PC_IV_L1_PT_EN.<br>Debug or Prefetch PTW Cache Invalid Level1 Page Table Enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 18             | R/W        | 0x0         | DBG_PF_DRAM_IV_L1_PT_EN.<br>Debug or Prefetch DRAM Invalid Level1 Page Table Enable<br>0: Mask interrupt<br>1: Enable interrupt    |
| 17             | R/W        | 0x0         | L2_PAGE_TABLE_INVALID_EN<br>Level2 page table invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                 |
| 16             | R/W        | 0x0         | L1_PAGE_TABLE_INVALID_EN<br>Level1 page table invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                 |
| 15:7           | /          | /           | /                                                                                                                                  |
| 6              | R/W        | 0x0         | MICRO_TLB6_INVALID_EN                                                                                                              |

| Offset: 0x0100 |            |             | Register Name: IOMMU_INT_ENABLE_REG                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
|                |            |             | Micro TLB6 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt                          |
| 5              | R/W        | 0x0         | MICRO_TLB5_INVALID_EN<br>Micro TLB5 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 4              | R/W        | 0x0         | MICRO_TLB4_INVALID_EN<br>Micro TLB4 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 3              | R/W        | 0x0         | MICRO_TLB3_INVALID_EN<br>Micro TLB3 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 2              | R/W        | 0x0         | MICRO_TLB2_INVALID_EN<br>Micro TLB2 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 1              | R/W        | 0x0         | MICRO_TLB1_INVALID_EN<br>Micro TLB1 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |
| 0              | R/W        | 0x0         | MICRO_TLB0_INVALID_EN<br>Micro TLB0 permission invalid interrupt enable<br>0: Mask interrupt<br>1: Enable interrupt |

### 3.13.6.33 0x0104 IOMMU Interrupt Clear Register (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: IOMMU_INT_CLR_REG                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:18          | /          | /           | /                                                                                                  |
| 17             | W          | 0x0         | L2_PAGE_TABLE_INVALID_CLR<br>Level2 page table invalid interrupt clear bit<br>0: Invalid operation |

| Offset: 0x0104 |            |             | Register Name: IOMMU_INT_CLR_REG                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
|                |            |             | 1: Clear interrupt                                                                                                                                             |
| 16             | W          | 0x0         | L1_PAGE_TABLE_INVALID_CLR<br>Level1 page table invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                       |
| 15:7           | /          | /           | /                                                                                                                                                              |
| 6              | W          | 0x0         | MICRO_TLB6_INVALID_CLR<br>Micro TLB6 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt<br><b>Note: The bit is not used.</b> |
| 5              | W          | 0x0         | MICRO_TLB5_INVALID_CLR<br>Micro TLB5 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |
| 4              | W          | 0x0         | MICRO_TLB4_INVALID_CLR<br>Micro TLB4 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |
| 3              | W          | 0x0         | MICRO_TLB3_INVALID_CLR<br>Micro TLB3 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |
| 2              | W          | 0x0         | MICRO_TLB2_INVALID_CLR<br>Micro TLB2 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |
| 1              | W          | 0x0         | MICRO_TLB1_INVALID_CLR<br>Micro TLB1 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |
| 0              | W          | 0x0         | MICRO_TLB0_INVALID_CLR<br>Micro TLB0 permission invalid interrupt clear bit<br>0: Invalid operation<br>1: Clear interrupt                                      |

## 3.13.6.34 0x0108 IOMMU Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: IOMMU_INT_STA_REG                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 31:18          | /          | /           | /                                                                                                                                                                                                 |
| 17             | R          | 0x0         | L2_PAGE_TABLE_INVALID_STA<br>Level2 page table invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                       |
| 16             | R          | 0x0         | L1_PAGE_TABLE_INVALID_STA<br>Level1 page table invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                       |
| 15:7           | /          | /           | /                                                                                                                                                                                                 |
| 6              | R          | 0x0         | MICRO_TLB6_INVALID_STA<br>Micro TLB6 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens<br><b>Note: The bit is not used.</b> |
| 5              | R          | 0x0         | MICRO_TLB5_INVALID_STA<br>Micro TLB5 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 4              | R          | 0x0         | MICRO_TLB4_INVALID_STA<br>Micro TLB4 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 3              | R          | 0x0         | MICRO_TLB3_INVALID_STA<br>Micro TLB3 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 2              | R          | 0x0         | MICRO_TLB2_INVALID_STA<br>Micro TLB2 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |
| 1              | R          | 0x0         | MICRO_TLB1_INVALID_STA<br>Micro TLB1 permission invalid interrupt status bit<br>0: Interrupt does not happen or interrupt is cleared<br>1: Interrupt happens                                      |

| Offset: 0x0108 |            |             | Register Name: IOMMU_INT_STA_REG                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                            |
| 0              | R          | 0x0         | <p>MICRO_TLBO_INVALID_STA<br/>Micro TLBO permission invalid interrupt status bit<br/>0: Interrupt does not happen or interrupt is cleared<br/>1: Interrupt happens</p> |

### 3.13.6.35 0x0110 IOMMU Interrupt Error Address 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: IOMMU_INT_ERR_ADDR0_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | <p>INT_ERR_ADDR0<br/>Virtual address that caused Micro TLB0 to interrupt</p> |

### 3.13.6.36 0x0114 IOMMU Interrupt Error Address 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: IOMMU_INT_ERR_ADDR1_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | <p>INT_ERR_ADDR1<br/>Virtual address that caused Micro TLB1 to interrupt</p> |

### 3.13.6.37 0x0118 IOMMU Interrupt Error Address 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0118 |            |             | Register Name: IOMMU_INT_ERR_ADDR2_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | <p>INT_ERR_ADDR2<br/>Virtual address that caused Micro TLB2 to interrupt</p> |

### 3.13.6.38 0x011C IOMMU Interrupt Error Address 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x011C |            |             | Register Name: IOMMU_INT_ERR_ADDR3_REG                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | <p>INT_ERR_ADDR3<br/>Virtual address that caused Micro TLB3 to interrupt</p> |

**3.13.6.39 0x0120 IOMMU Interrupt Error Address 4 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0120 |            |             | Register Name: IOMMU_INT_ERR_ADDR4_REG                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR4<br>Virtual address that caused Micro TLB4 to interrupt |

**3.13.6.40 0x0124 IOMMU Interrupt Error Address 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0124 |            |             | Register Name: IOMMU_INT_ERR_ADDR5_REG                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR5<br>Virtual address that caused Micro TLB5 to interrupt |

**3.13.6.41 0x0128 IOMMU Interrupt Error Address 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0128 |            |             | Register Name: IOMMU_INT_ERR_ADDR6_REG                               |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:0           | R          | 0x0         | INT_ERR_ADDR6<br>Virtual address that caused Micro TLB6 to interrupt |

**3.13.6.42 0x0130 IOMMU Interrupt Error Address 7 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0130 |            |             | Register Name: IOMMU_INT_ERR_ADDR7_REG                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:0           | R          | 0x0         | INT_ERR_ADDR7<br>Virtual address that caused L1 page table to interrupt |

**3.13.6.43 0x0134 IOMMU Interrupt Error Address 8 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0134 |            |             | Register Name: IOMMU_INT_ERR_ADDR8_REG                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:0           | R          | 0x0         | INT_ERR_ADDR8<br>Virtual address that caused L2 page table to interrupt |

### 3.13.6.44 0x0150 IOMMU Interrupt Error Data 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0150 |            |             | Register Name: IOMMU_INT_ERR_DATA0_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA0<br>Corresponding page table of virtual address that caused Micro TLBO to interrupt |

### 3.13.6.45 0x0154 IOMMU Interrupt Error Data 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0154 |            |             | Register Name: IOMMU_INT_ERR_DATA1_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA1<br>Corresponding page table of virtual address that caused Micro TLB1 to interrupt |

### 3.13.6.46 0x0158 IOMMU Interrupt Error Data 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0158 |            |             | Register Name: IOMMU_INT_ERR_DATA2_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA2<br>Corresponding page table of virtual address that caused Micro TLB2 to interrupt |

### 3.13.6.47 0x015C IOMMU Interrupt Error Data 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x015C |            |             | Register Name: IOMMU_INT_ERR_DATA3_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA3<br>Corresponding page table of virtual address that caused Micro TLB3 to interrupt |

**3.13.6.48 0x0160 IOMMU Interrupt Error Data 4 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0160 |            |             | Register Name: IOMMU_INT_ERR_DATA4_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA4<br>Corresponding page table of virtual address that caused Micro TLB4 to interrupt |

**3.13.6.49 0x0164 IOMMU Interrupt Error Data 5 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0164 |            |             | Register Name: IOMMU_INT_ERR_DATA5_REG                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:0           | R          | 0x0         | INT_ERR_DATA5<br>Corresponding page table of virtual address that caused Micro TLB5 to interrupt |

**3.13.6.50 0x0168 IOMMU Interrupt Error Data 6 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0168 |            |             | Register Name: IOMMU_INT_ERR_DATA6_REG                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:0           | R          | 0x0         | INT_ERR_DATA6<br>Corresponding page table of virtual address that caused Micro TLB6 to interrupt<br><b>Note: This field is not used.</b> |

**3.13.6.51 0x0170 IOMMU Interrupt Error Data 7 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0170 |            |             | Register Name: IOMMU_INT_ERR_DATA7_REG                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:0           | R          | 0x0         | INT_ERR_DATA7<br>Corresponding page table of virtual address that caused L1 page table to interrupt |

### 3.13.6.52 0x0174 IOMMU Interrupt Error Data 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x0174 |            |             | Register Name: IOMMU_INT_ERR_DATA8_REG                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:0           | R          | 0x0         | INT_ERR_DATA8<br>Corresponding page table of virtual address that caused L2 page table to interrupt |

### 3.13.6.53 0x0180 IOMMU L1 Page Table Interrupt Register (Default Value: 0x0000\_0000)

| Offset: 0x0180 |            |             | Register Name: IOMMU_L1PG_INT_REG                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31             | R          | 0x0         | DBG_MODE_L1PG_INT<br>Debug mode address switch causes L1 page table to occur interrupt.                                  |
| 30:7           | /          | /           | /                                                                                                                        |
| 6              | R          | 0x0         | MASTER6_L1PG_INT<br>Master6 address switch causes L1 page table to occur interrupt.<br><b>Note: The bit is not used.</b> |
| 5              | R          | 0x0         | MASTER5_L1PG_INT<br>Master5 address switch causes L1 page table to occur interrupt.                                      |
| 4              | R          | 0x0         | MASTER4_L1PG_INT<br>Master4 address switch causes L1 page table to occur interrupt.                                      |
| 3              | R          | 0x0         | MASTER3_L1PG_INT<br>Master3 address switch causes L1 page table to occur interrupt.                                      |
| 2              | R          | 0x0         | MASTER2_L1PG_INT<br>Master2 address switch causes L1 page table to occur interrupt.                                      |
| 1              | R          | 0x0         | MASTER1_L1PG_INT<br>Master1 address switch causes L1 page table to occur interrupt.                                      |
| 0              | R          | 0x0         | MASTER0_L1PG_INT<br>Master0 address switch causes L1 page table to occur interrupt.                                      |

### 3.13.6.54 0x0184 IOMMU L2 Page Table Interrupt Register (Default Value: 0x0000\_0000)

| Offset: 0x0184 |            |             | Register Name: IOMMU_L2PG_INT_REG |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31             | R          | 0x0         | DBG_MODE_L2PG_INT                 |

| Offset: 0x0184 |            |             | Register Name: IOMMU_L2PG_INT_REG                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
|                |            |             | Debug mode address switch causes L2 page table to occur interrupt.                                                       |
| 30:7           | /          | /           | /                                                                                                                        |
| 6              | R          | 0x0         | MASTER6_L2PG_INT<br>Master6 address switch causes L2 page table to occur interrupt.<br><b>Note: The bit is not used.</b> |
| 5              | R          | 0x0         | MASTER5_L2PG_INT<br>Master5 address switch causes L2 page table to occur interrupt.                                      |
| 4              | R          | 0x0         | MASTER4_L2PG_INT<br>Master4 address switch causes L2 page table to occur interrupt.                                      |
| 3              | R          | 0x0         | MASTER3_L2PG_INT<br>Master3 address switch causes L2 page table to occur interrupt.                                      |
| 2              | R          | 0x0         | MASTER2_L2PG_INT<br>Master2 address switch causes L2 page table to occur interrupt.                                      |
| 1              | R          | 0x0         | MASTER1_L2PG_INT<br>Master1 address switch causes L2 page table to occur interrupt.                                      |
| 0              | R          | 0x0         | MASTER0_L2PG_INT<br>Master0 address switch causes L2 page table to occur interrupt.                                      |

### 3.13.6.55 0x0190 IOMMU Virtual Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0190 |            |             | Register Name: IOMMU_VA_REG         |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R/W        | 0x0         | VA<br>Virtual address of read/write |

### 3.13.6.56 0x0194 IOMMU Virtual Address Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: IOMMU_VA_DATA_REG                            |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:0           | R/W        | 0x0         | VA_DATA<br>Data corresponding to read/write virtual address |

### 3.13.6.57 0x0198 IOMMU Virtual Address Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0198 |            |             | Register Name: IOMMU_VA_CONFIG_REG                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 31             | R/W        | 0x0         | MODE_SEL<br>0: Prefetch<br>1: Debug Mode<br>It is used to chose prefetch mode or Debug mode.                                                   |
| 31:9           | /          | /           | /                                                                                                                                              |
| 8              | R/W        | 0x0         | VA_CONFIG<br>Virtual Address Configuration<br>0: Read operation<br>1: Write operation                                                          |
| 7:1            | /          | /           | /                                                                                                                                              |
| 0              | R/WAC      | 0x0         | VA_CONFIG_START<br>0: No operation or operation is completed<br>1: Start<br>After the operation is completed, the bit can clear automatically. |

Read operation process:

- Write IOMMU\_VA\_REG[31:0];
- Write IOMMU\_VA\_CONFIG\_REG[8] to 0;
- Write IOMMU\_VA\_CONFIG\_REG[0] to 1 to start read-process;
- Query IOMMU\_VA\_CONFIG\_REG[0] until it is 0;
- Read IOMMU\_VA\_DATA\_REG[31:0];

Write operation process:

- Write IOMMU\_VA\_REG[31:0];
- Write IOMMU\_VA\_DATA\_REG[31:0];
- Write IOMMU\_VA\_CONFIG\_REG[8] to 1;
- Write IOMMU\_VA\_CONFIG\_REG[0] to 1 to start write-process;
- Query IOMMU\_VA\_CONFIG\_REG[0] until it is 0;

### 3.13.6.58 0x0200 IOMMU PMU Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: IOMMU_PMU_ENABLE_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:1           | /          | /           | /                                   |
| 0              | R/W        | 0x0         | PMU_ENABLE                          |

| Offset: 0x0200 |            |             | Register Name: IOMMU_PMU_ENABLE_REG                               |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
|                |            |             | 0: Disable statistical function<br>1: Enable statistical function |

### 3.13.6.59 0x0210 IOMMU PMU Clear Register (Default Value: 0x0000\_0000)

| Offset: 0x0210 |            |             | Register Name: IOMMU_PMU_CLR_REG                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:1           | /          | /           | /                                                                                                                                                               |
| 0              | R/WAC      | 0x0         | PMU_CLR<br>0: No clear operation or clear operation is completed<br>1: Clear counter data<br>After the operation is completed, the bit can clear automatically. |

### 3.13.6.60 0x0230 IOMMU PMU Access Low 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW0_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW0<br>Record total number of Micro TLB0 access, lower 32-bit register |

### 3.13.6.61 0x0234 IOMMU PMU Access High 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH0_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH0<br>Record total number of Micro TLB0 access, higher 11-bit register |

### 3.13.6.62 0x0238 IOMMU PMU Hit Low 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: IOMMU_PMU_HIT_LOW0_REG |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:0           | R          | 0x0         | PMU_HIT_LOW0                          |

| Offset: 0x0238 |            |             | Register Name: IOMMU_PMU_HIT_LOW0_REG                        |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
|                |            |             | Record total number of Micro TLB0 hit, lower 32-bit register |

### 3.13.6.63 0x023C IOMMU PMU Hit High 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x023C |            |             | Register Name: IOMMU_PMU_HIT_HIGH0_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH0<br>Record total number of Micro TLB0 hit, higher 11-bit register |

### 3.13.6.64 0x0240 IOMMU PMU Access Low 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW1_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW1<br>Record total number of Micro TLB1 access, lower 32-bit register |

### 3.13.6.65 0x0244 IOMMU PMU Access High 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0244 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH1_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH1<br>Record total number of Micro TLB1 access, higher 11-bit register |

### 3.13.6.66 0x0248 IOMMU PMU Hit Low 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: IOMMU_PMU_HIT_LOW1_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW1<br>Record total number of Micro TLB1 hit, lower 32-bit register |

### 3.13.6.67 0x024C IOMMU PMU Hit High 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x024C |            |             | Register Name: IOMMU_PMU_HIT_HIGH1_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH1<br>Record total number of Micro TLB1 hit, higher 11-bit register |

### 3.13.6.68 0x0250 IOMMU PMU Access Low 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0250 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW2_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW2<br>Record total number of Micro TLB2 access, lower 32-bit register |

### 3.13.6.69 0x0254 IOMMU PMU Access High 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0254 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH2_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH2<br>Record total number of Micro TLB2 access, higher 11-bit register |

### 3.13.6.70 0x0258 IOMMU PMU Hit Low 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0258 |            |             | Register Name: IOMMU_PMU_HIT_LOW2_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW2<br>Record total number of Micro TLB2 hit, lower 32-bit register |

### 3.13.6.71 0x025C IOMMU PMU Hit High 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x025C |            |             | Register Name: IOMMU_PMU_HIT_HIGH2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:11          | /          | /           | /                                      |

| Offset: 0x025C |            |             | Register Name: IOMMU_PMU_HIT_HIGH2_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH2<br>Record total number of Micro TLB2 hit, higher 11-bit register |

### 3.13.6.72 0x0260 IOMMU PMU Access Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0260 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW3_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW3<br>Record total number of Micro TLB3 access, lower 32-bit register |

### 3.13.6.73 0x0264 IOMMU PMU Access High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0264 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH3_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH3<br>Record total number of Micro TLB3 access, higher 11-bit register |

### 3.13.6.74 0x0268 IOMMU PMU Hit Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0268 |            |             | Register Name: IOMMU_PMU_HIT_LOW3_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW3<br>Record total number of Micro TLB3 hit, lower 32-bit register |

### 3.13.6.75 0x026C IOMMU PMU Hit High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x026C |            |             | Register Name: IOMMU_PMU_HIT_HIGH3_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH3<br>Record total number of Micro TLB3 hit, higher 11-bit register |

### 3.13.6.76 0x0270 IOMMU PMU Access Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0270 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW4_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW4<br>Record total number of Micro TLB4 access, lower 32-bit register |

### 3.13.6.77 0x0274 IOMMU PMU Access High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0274 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH4_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH4<br>Record total number of Micro TLB4 access, higher 11-bit register |

### 3.13.6.78 0x0278 IOMMU PMU Hit Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: IOMMU_PMU_HIT_LOW4_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW4<br>Record total number of Micro TLB4 hit, lower 32-bit register |

### 3.13.6.79 0x027C IOMMU PMU Hit High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x027C |            |             | Register Name: IOMMU_PMU_HIT_HIGH4_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH4<br>Record total number of Micro TLB4 hit, higher 11-bit register |

### 3.13.6.80 0x0280 IOMMU PMU Access Low 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0280 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW5_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW5<br>Record total number of Micro TLB5 access, lower 32-bit register |

### 3.13.6.81 0x0284 IOMMU PMU Access High 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0284 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH5_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH5<br>Record total number of Micro TLB5 access, higher 11-bit register |

### 3.13.6.82 0x0288 IOMMU PMU Hit Low 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0288 |            |             | Register Name: IOMMU_PMU_HIT_LOW5_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW5<br>Record total number of Micro TLB5 hit, lower 32-bit register |

### 3.13.6.83 0x028C IOMMU PMU Hit High 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x028C |            |             | Register Name: IOMMU_PMU_HIT_HIGH5_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH5<br>Record total number of Micro TLB5 hit, higher 11-bit register |

### 3.13.6.84 0x0290 IOMMU PMU Access Low 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0290 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW6_REG                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW6<br>Record total number of Micro TLB6 access, lower 32-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.85 0x0294 IOMMU PMU Access High 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0294 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH6_REG                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:11          | /          | /           | /                                                                                                                           |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH6<br>Record total number of Micro TLB6 access, higher 11-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.86 0x0298 IOMMU PMU Hit Low 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0298 |            |             | Register Name: IOMMU_PMU_HIT_LOW6_REG                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                         |
| 31:0           | R          | 0x0         | PMU_HIT_LOW6<br>Record total number of Micro TLB6 hit, lower 32-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.87 0x029C IOMMU PMU Hit High 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x029C |            |             | Register Name: IOMMU_PMU_HIT_HIGH6_REG                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:11          | /          | /           | /                                                                                                                     |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH6<br>Record total number of Micro TLB6 hit, higher 11-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.88 0x02D0 IOMMU PMU Access Low 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02D0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW7_REG                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW7<br>Record total number of Micro TLB7 access, lower 32-bit register |

### 3.13.6.89 0x02D4 IOMMU PMU Access High 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02D4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH7_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:11          | /          | /           | /                                                                                    |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH7<br>Record total number of Micro TLB7 access, higher 11-bit register |

### 3.13.6.90 0x02D8 IOMMU PMU Hit Low 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02D8 |            |             | Register Name: IOMMU_PMU_HIT_LOW7_REG                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R          | 0x0         | PMU_HIT_LOW7<br>Record total number of Micro TLB7 hit, lower 32-bit register |

### 3.13.6.91 0x02DC IOMMU PMU Hit High 7 Register (Default Value: 0x0000\_0000)

| Offset: 0x02DC |            |             | Register Name: IOMMU_PMU_HIT_HIGH7_REG                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:11          | /          | /           | /                                                                              |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH7<br>Record total number of Micro TLB7 hit, higher 11-bit register |

### 3.13.6.92 0x02E0 IOMMU PMU Access Low 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E0 |            |             | Register Name: IOMMU_PMU_ACCESS_LOW8_REG                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:0           | R          | 0x0         | PMU_ACCESS_LOW8<br>Record total number of PTW Cache access, lower 32-bit register |

### 3.13.6.93 0x02E4 IOMMU PMU Access High 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH8_REG |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:11          | /          | /           | /                                         |

| Offset: 0x02E4 |            |             | Register Name: IOMMU_PMU_ACCESS_HIGH8_REG                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 10:0           | R          | 0x0         | PMU_ACCESS_HIGH8<br>Record total number of PTW Cache access, higher 11-bit register |

### 3.13.6.94 0x02E8 IOMMU PMU Hit Low 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02E8 |            |             | Register Name: IOMMU_PMU_HIT_LOW8_REG                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:0           | R          | 0x0         | PMU_HIT_LOW8<br>Record total number of PTW Cache hit, lower 32-bit register |

### 3.13.6.95 0x02EC IOMMU PMU Hit High 8 Register (Default Value: 0x0000\_0000)

| Offset: 0x02EC |            |             | Register Name: IOMMU_PMU_HIT_HIGH8_REG                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:11          | /          | /           | /                                                                             |
| 10:0           | R          | 0x0         | PMU_HIT_HIGH8<br>Record total number of PTW Cache hit, higher 11-bit register |

### 3.13.6.96 0x0300 IOMMU Total Latency Low 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: IOMMU_PMU_TL_LOW0_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW0<br>Record total latency of Master0, lower 32-bit register |

### 3.13.6.97 0x0304 IOMMU Total Latency High 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0304 |            |             | Register Name: IOMMU_PMU_TL_HIGH0_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH0<br>Record total latency of Master0, higher 18-bit register |

### 3.13.6.98 0x0308 IOMMU Max Latency 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0308 |            |             | Register Name: IOMMU_PMU_ML0_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML0<br>Record the max latency of Master0. |

### 3.13.6.99 0x0310 IOMMU Total Latency Low 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0310 |            |             | Register Name: IOMMU_PMU_TL_LOW1_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW1<br>Record total latency of Master1, lower 32-bit register |

### 3.13.6.100 0x0314 IOMMU Total Latency High 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0314 |            |             | Register Name: IOMMU_PMU_TL_HIGH1_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH1<br>Record total latency of Master1, higher 18-bit register |

### 3.13.6.101 0x0318 IOMMU Max Latency 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0318 |            |             | Register Name: IOMMU_PMU_ML1_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML1<br>Record the max latency of Master1. |

### 3.13.6.102 0x0320 IOMMU Total Latency Low 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0320 |            |             | Register Name: IOMMU_PMU_TL_LOW2_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW2<br>Record total latency of Master2, lower 32-bit register |

### 3.13.6.103 0x0324 IOMMU Total Latency High 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0324 |            |             | Register Name: IOMMU_PMU_TL_HIGH2_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH2<br>Record total latency of Master2, higher 18-bit register |

### 3.13.6.104 0x0328 IOMMU Max Latency 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0328 |            |             | Register Name: IOMMU_PMU_ML2_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML2<br>Record the max latency of Master2. |

### 3.13.6.105 0x0330 IOMMU Total Latency Low 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0330 |            |             | Register Name: IOMMU_PMU_TL_LOW3_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW3<br>Record total latency of Master3, lower 32-bit register |

### 3.13.6.106 0x0334 IOMMU Total Latency High 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: IOMMU_PMU_TL_HIGH3_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH3<br>Record total latency of Master3, higher 18-bit register |

### 3.13.6.107 0x0338 IOMMU Max Latency 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0338 |            |             | Register Name: IOMMU_PMU_ML3_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML3<br>Record the max latency of Master3. |

### 3.13.6.108 0x0340 IOMMU Total Latency Low 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: IOMMU_PMU_TL_LOW4_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW4<br>Record total latency of Master4, lower 32-bit register |

### 3.13.6.109 0x0344 IOMMU Total Latency High 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: IOMMU_PMU_TL_HIGH4_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH4<br>Record total latency of Master4, higher 18-bit register |

### 3.13.6.110 0x0348 IOMMU Max Latency 4 Register (Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: IOMMU_PMU_ML4_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML4<br>Record the max latency of Master4. |

### 3.13.6.111 0x0350 IOMMU Total Latency Low 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0350 |            |             | Register Name: IOMMU_PMU_TL_LOW5_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | PMU_TL_LOW5<br>Record total latency of Master5, lower 32-bit register |

### 3.13.6.112 0x0354 IOMMU Total Latency High 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0354 |            |             | Register Name: IOMMU_PMU_TL_HIGH5_REG                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:18          | /          | /           | /                                                                       |
| 17:0           | R          | 0x0         | PMU_TL_HIGH5<br>Record total latency of Master5, higher 18-bit register |

### 3.13.6.113 0x0358 IOMMU Max Latency 5 Register (Default Value: 0x0000\_0000)

| Offset: 0x0358 |            |             | Register Name: IOMMU_PMU_ML5_REG              |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:0           | R          | 0x0         | PMU_ML5<br>Record the max latency of Master5. |

### 3.13.6.114 0x0360 IOMMU Total Latency Low 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0360 |            |             | Register Name: IOMMU_PMU_TL_LOW6_REG                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
| 31:0           | R          | 0x0         | PMU_TL_LOW6<br>Record total latency of Master6, lower 32-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.115 0x0364 IOMMU Total Latency High 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0364 |            |             | Register Name: IOMMU_PMU_TL_HIGH6_REG                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31:18          | /          | /           | /                                                                                                              |
| 17:0           | R          | 0x0         | PMU_TL_HIGH6<br>Record total latency of Master6, higher 18-bit register<br><b>Note: The field is not used.</b> |

### 3.13.6.116 0x0368 IOMMU Max Latency 6 Register (Default Value: 0x0000\_0000)

| Offset: 0x0368 |            |             | Register Name: IOMMU_PMU_ML6_REG                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:0           | R          | 0x0         | PMU_ML6<br>Record the max latency of Master6.<br><b>Note:</b> The field is not used. |

## 3.14 Message Box

### 3.14.1 Overview

The Message Box (MSGBOX) provides interrupt communication mechanism for on-chip processor.

The MSGBOX has the following features:

- Supports 2 CPU to transmit information through channels. Each CPU has a MSGBOX.
  - CPU 0: ARM CPUX
  - CPU 1: DSP
  - CPU 2: RISC-V
- The channel between two CPU has 4 channels, and the FIFO depth of a channel is  $8 \times 32$  bits
- Supports interrupts

### 3.14.2 Block Diagram

The following figure shows the block diagram of the message box.

Figure 3-37 Message Box Block Diagram



For MSGBOX0, CPU1: write; CPU0: read  
For MSGBOX1, CPU0: write; CPU1: read

Each CPU has 4 channels. The two channels can be configured to be secure by software, the other two channels can be configured to be non-secure by software. The two secure channels or two non-secure channels can be

configured as one synchronous box (Sending a message requires a response) or one asynchronous box (Sending a message does not require a response),

### 3.14.3 Functional Description

#### 3.14.3.1 Clock and Reset

The MSGBOX is mounted on AHB0. Before accessing the MSGBOX registers, you need to de-assert the MSGBOX reset signal on AHB0 bus and then open the MSGBOX gating signal on AHB0 bus.

#### 3.14.3.2 Typical Application

Several masters can build communication by configuring the MSGBOX. The communication parties have 4 channels. In a channel, the user1 is fixed as the transmitter and the user0 is fixed as the receiver. During the communication process, the current status can be judged through the interrupt or FIFO status.

#### 3.14.3.3 Transmitter/Receiver Mode

At the same channel, user1 is fixed as transmitter, user0 is fixed as receiver.

#### 3.14.3.4 Interrupt

Each channel can configure independently the interrupt enable bit, a read interrupt will be generated when the channel is empty, a write interrupt will be generated when the channel is non-full. For each CPU, all channels generate a read interrupt together, that is, if only a channel is non-full, the read interrupt will be generated, this channel can be obtained by querying the interrupt status register.

#### 3.14.3.5 FIFO Status

When channel FIFO is non-full, the FIFO\_FULL\_FLAG is 0, at the moment the FIFO can be written.

When channel FIFO is full, the FIFO\_FULL\_FLAG is 1, at the moment if FIFO is written again, the first data of FIFO can be covered.

See [MSGBOX\\_MSG\\_STATUS\\_REG](#) for FIFO status.

### 3.14.4 Programming Guidelines

#### 3.14.4.1 Checking the Transfer Status via the Interrupt

Follow the steps below to check the transfer status:

**Step 1** Enable the interrupt for the channel: Configure the interrupt enable bits of transmitter/receiver through [MSGBOX WR IRQ\\_EN REG/MSGBOX RD IRQ\\_EN REG](#). (user1: RX interrupt enable; user2: TX interrupt enable)

**Step 2** Check the IRQ status of the corresponding queue through [MSGBOX WR IRQ\\_STATUS REG/MSGBOX RD IRQ\\_STATUS REG](#).

- If the FIFO is not full, the channel generates a transmission interrupt to remind the transmitter to transmit data. Write data to the FIFO in the interrupt handler, then clear the pending bit of the transmitter in [MSGBOX WR IRQ\\_STATUS REG](#) and the enable bit of the transmitter in [MSGBOX WR IRQ\\_EN REG](#).
- If the FIFO has new data, the channel generates a reception interrupt to remind the receiver to receive data. Read data from the FIFO in interrupt handler, then clear the pending bit of the receiver in [MSGBOX RD IRQ\\_STATUS REG](#) and the enable bit of the receiver in [MSGBOX RD IRQ\\_EN REG](#).

#### 3.14.4.2 Checking the Transfer Status via the FIFO

Follow the steps below to check the FIFO status of the corresponding queue:

- If the FIFO is not full, the transmitter fills the FIFO to 8\*32 bits.
- If the FIFO is full, the receiver reads the FIFO data, and reads [MSGBOX FIFO STATUS REG](#) to acquire the current FIFO data amount and the FIFO data amount before reading, which means no data is dropped.

#### 3.14.4.3 Transmitting/Receiving Message

The following figure shows the communication process between MSGBOX0 and MSGBOX1.

MSGBOX0: receiving message

MSGBOX1: transmitting message

Figure 3-38 The Communication Process between MSGBOX0 and MSGBOX1



### 3.14.5 Register List

| Module Name     | Base Address |
|-----------------|--------------|
| ARM CPUX_MSGBOX | 0x03003000   |
| DSP_MSGBOX      | 0x01701000   |
| RISC-V_MSGBOX   | 0x0601F000   |

| Symbol | Description                                            | Value |
|--------|--------------------------------------------------------|-------|
| N      | The CPU numbers that communicates with the current CPU | 0~1   |
| P      | The channel numbers between two communication users    | 0~3   |

| MSGBOX            | CPU           | The Value of N |
|-------------------|---------------|----------------|
| MSGBOX (ARM CPUX) | DSP->CPUX     | N=0            |
| MSGBOX (ARM CPUX) | RISCV->CPUX   | N=1            |
| MSGBOX (DSP)      | CPUX->DSP     | N=0            |
| MSGBOX (DSP)      | RISC-V -> DSP | N=1            |
| MSGBOX (RISC-V)   | CPUX->RISCV   | N=0            |
| MSGBOX (RISC-V)   | DSP -> RISC-V | N=1            |

| Register Name               | Offset                                  | Description                         |
|-----------------------------|-----------------------------------------|-------------------------------------|
| MSGBOX_RD_IRQ_EN_REG        | 0x0020+N*0x0100 (N=0-1)                 | MSGBOX Read IRQ Enable Register     |
| MSGBOX_RD_IRQ_STATUS_REG    | 0x0024+N*0x0100 (N=0-1)                 | MSGBOX Read IRQ Status Register     |
| MSGBOX_WR_IRQ_EN_REG        | 0x0030+N*0x0100 (N=0-1)                 | MSGBOX Write IRQ Enable Register    |
| MSGBOX_WR_IRQ_STATUS_REG    | 0x0034+N*0x0100 (N=0-1)                 | MSGBOX Write IRQ Status Register    |
| MSGBOX_DEBUG_REG            | 0x0040+N*0x0100 (N=0-1)                 | MSGBOX Debug Register               |
| MSGBOX_FIFO_STATUS_REG      | 0x0050+N*0x0100+P*0x0004 (N=0-1)(P=0-3) | MSGBOX FIFO Status Register         |
| MSGBOX_MSG_STATUS_REG       | 0x0060+N*0x0100+P*0x0004 (N=0-1)(P=0-3) | MSGBOX Message Status Register      |
| MSGBOX_MSG_REG              | 0x0070+N*0x0100+P*0x0004 (N=0-1)(P=0-3) | MSGBOX Message Queue Register       |
| MSGBOX_WR_INT_THRESHOLD_REG | 0x0080+N*0x0100+P*0x0004 (N=0-1)(P=0-3) | MSGBOX Write IRQ Threshold Register |

### 3.14.6 Register Description

#### 3.14.6.1 0x0020 + N\*0x0100 MSGBox Read IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 + N*0x0100 (N=0-1) |            |             | Register Name: MSGBOX_RD_IRQ_EN_REG |
|-----------------------------------|------------|-------------|-------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                         |
| 31:7                              | /          | /           | /                                   |

| Offset: 0x0020 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_RD_IRQ_EN_REG                                                                                                                                   |
|-----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 6                                 | R/W        | 0x0         | RECEPTION_MQ3_IRQ_EN<br>Reception Channel3 Interrupt Enable<br>0: Disable<br>1: Enable (It notifies user 0 by interrupt when Message Queue 3 received a new message.) |
| 5                                 | /          | /           | /                                                                                                                                                                     |
| 4                                 | R/W        | 0x0         | RECEPTION_MQ2_IRQ_EN<br>Reception Channel2 Interrupt Enable<br>0: Disable<br>1: Enable (It notifies user 0 by interrupt when Message Queue 2 received a new message.) |
| 3                                 | /          | /           | /                                                                                                                                                                     |
| 2                                 | R/W        | 0x0         | RECEPTION_MQ1_IRQ_EN<br>Reception Channel1 Interrupt Enable<br>0: Disable<br>1: Enable (It notifies user 0 by interrupt when Message Queue 1 received a new message.) |
| 1                                 | /          | /           | /                                                                                                                                                                     |
| 0                                 | R/W        | 0x0         | RECEPTION_MQ0_IRQ_EN<br>Reception Channel0 Interrupt Enable<br>0: Disable<br>1: Enable (It notifies user 0 by interrupt when Message Queue 0 received a new message.) |

### 3.14.6.2 0x0024 + N\*0x0100 MSGBox Read IRQ Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_RD_IRQ_STATUS_REG                                                                                                                                 |
|-----------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:7                              | /          | /           | /                                                                                                                                                                       |
| 6                                 | R/W1C      | 0x0         | RECEPTION_MQ3_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 3 received a new message. Setting 1 to this bit clears it. |
| 5                                 | /          | /           | /                                                                                                                                                                       |

| Offset: 0x0024 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_RD_IRQ_STATUS_REG                                                                                                                                 |
|-----------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 4                                 | R/W1C      | 0x0         | RECEPTION_MQ2_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 2 received a new message. Setting 1 to this bit clears it. |
| 3                                 | /          | /           | /                                                                                                                                                                       |
| 2                                 | R/W1C      | 0x0         | RECEPTION_MQ1_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 1 received a new message. Setting 1 to this bit clears it. |
| 1                                 | /          | /           | /                                                                                                                                                                       |
| 0                                 | R/W1C      | 0x0         | RECEPTION_MQ0_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 0 when Message Queue 0 received a new message. Setting 1 to this bit clears it. |

### 3.14.6.3 0x0030 + N\*0x0100 MSGBox Write IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_WR_IRQ_EN_REG                                                                                                                 |
|-----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:8                              | /          | /           | /                                                                                                                                                   |
| 7                                 | R/W        | 0x0         | TRANSMIT_MQ3_IRQ_EN<br>0: Disable<br>1: Enable (It notifies user 1 by interrupt when Message Queue 3 empty level reaches the configured threshold.) |
| 6                                 | /          | /           | /                                                                                                                                                   |
| 5                                 | R/W        | 0x0         | TRANSMIT_MQ2_IRQ_EN<br>0: Disable<br>1: Enable (It notifies user 1 by interrupt when Message Queue 2 empty level reaches the configured threshold.) |
| 4                                 | /          | /           | /                                                                                                                                                   |
| 3                                 | R/W        | 0x0         | TRANSMIT_MQ1_IRQ_EN<br>0: Disable<br>1: Enable (It notifies user 1 by interrupt when Message Queue 1 empty level reaches the configured threshold.) |
| 2                                 | /          | /           | /                                                                                                                                                   |

| Offset: 0x0030 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_WR_IRQ_EN_REG                                                                                                                 |
|-----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                         |
| 1                                 | R/W        | 0x0         | TRANSMIT_MQ0_IRQ_EN<br>0: Disable<br>1: Enable (It notifies user 1 by interrupt when Message Queue 0 empty level reaches the configured threshold.) |
| 0                                 | /          | /           | /                                                                                                                                                   |

### 3.14.6.4 0x0034 + N\*0x0100 MSGBox Write IRQ Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 + N*0x0100 (N=0~1) |            |             | Register Name: MSGBOX_WR_IRQ_STATUS_REG                                                                                                                                                      |
|-----------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:8                              | /          | /           | /                                                                                                                                                                                            |
| 7                                 | R/W1C      | 0x0         | TRANSMIT_MQ3_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 3 empty level reaches the configured threshold. Setting 1 to this bit clears it. |
| 6                                 | /          | /           | /                                                                                                                                                                                            |
| 5                                 | R/W1C      | 0x0         | TRANSMIT_MQ2_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 2 empty level reaches the configured threshold. Setting 1 to this bit clears it. |
| 4                                 | /          | /           | /                                                                                                                                                                                            |
| 3                                 | R/W1C      | 0x0         | TRANSMIT_MQ1_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 1 empty level reaches the configured threshold. Setting 1 to this bit clears it. |
| 2                                 | /          | /           | /                                                                                                                                                                                            |
| 1                                 | R/W1C      | 0x0         | TRANSMIT_MQ0_IRQ_PEND<br>0: No effect<br>1: Pending. This bit will be pending for user 1 when Message Queue 0 empty level reaches the configured threshold. Setting 1 to this bit clears it. |
| 0                                 | /          | /           | /                                                                                                                                                                                            |

### 3.14.6.5 0x0050+N\*0x0100+P\*0x0004 MSGBox FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0050+N*0x0100+P*0x0004<br>(N=0~1)(P=0~3) |            |             | Register Name: MSGBOX_FIFO_STATUS_REG                                                                                                                                                                                                                                                                    |
|----------------------------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                              |
| 31: 1                                              | /          | /           | /                                                                                                                                                                                                                                                                                                        |
| 0                                                  | R          | 0x0         | <p>FIFO_NOT_AVA_FLAG<br/>FIFO is not available flag</p> <p>0: The Message FIFO queue empty level reaches the configured threshold</p> <p>1: The Message FIFO queue empty level does not reach the configured threshold</p> <p>This FIFO status register has the status related to the message queue.</p> |

### 3.14.6.6 0x0060+N\*0x0100+P\*0x0004 MSGBox Message Status Register m (Default Value: 0x0000\_0000)

| Offset: 0x0060+N*0x0100+P*0x0004<br>(N=0~1)(P=0~3) |            |             | Register Name: MSGBOX_MSG_STATUS_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:4                                               | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3:0                                                | R          | 0x0         | <p>MSG_NUM<br/>Message Number</p> <p>Number of unread messages in the message queue. Here, limited to eight messages per message queue.</p> <p>0000: There is no message in the message FIFO queue.</p> <p>0001: There is 1 message in the message FIFO queue.</p> <p>0010: There are 2 messages in the message FIFO queue.</p> <p>0011: There are 3 messages in the message FIFO queue.</p> <p>0100: There are 4 messages in the message FIFO queue.</p> <p>0101: There are 5 messages in the message FIFO queue.</p> <p>0110: There are 6 messages in the message FIFO queue.</p> <p>0111: There are 7 messages in the message FIFO queue.</p> <p>1000: There are 8 messages in the message FIFO queue.</p> <p>1001~1111: /</p> |

**3.14.6.7 0x0070+N\*0x0100+P\*0x0004 MSGBox Message Queue Register (Default Value: 0x0000\_0000)**

| Offset: 0x0070+N*0x0100+P*0x0004<br>(N=0~1)(P=0~3) |            |             | Register Name: MSGBOX_MSG_REG                                                                 |
|----------------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit                                                | Read/Write | Default/Hex | Description                                                                                   |
| 31:0                                               | R/W        | 0x0         | MSG_QUE<br>The message register stores the next to be read message of the message FIFO queue. |

**3.14.6.8 0x0080+N\*0x0100+P\*0x0004 MSGBox Write IRQ Threshold Register (Default Value: 0x0000\_0000)**

| Offset: 0x0080+N*0x0100+P*0x0004<br>(N=0~1)(P=0~3) |            |             | Register Name: MSGBOX_WR_INT_THRESHOLD_REG                                                                                              |
|----------------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:2                                               | /          | /           | /                                                                                                                                       |
| 1:0                                                | R/W        | 0x0         | MSG_WR_INT_THRESHOLD_CFG<br>Configure the FIFO empty level to trigger the write interrupt for user1<br>00: 1<br>01: 2<br>10: 4<br>11: 8 |

## 3.15 Spinlock

### 3.15.1 Overview

The spinlock provides hardware synchronization mechanism in multi-core systems. With the lock operation, the spinlock prevents multiple processors from handling the sharing data simultaneously and thus ensure the coherence of data.

The spinlock has the following features:

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

### 3.15.2 Block Diagram

The following figure shows the block diagram of the spinlock.

Figure 3-39 Spinlock Block Diagram



### 3.15.3 Functional Description

#### 3.15.3.1 Clock and Reset

The spinlock is mounted on AHBO. Before accessing the spinlock registers, you need to de-assert the reset signal on AHBO bus and then open the corresponding gating signal on AHBO bus.

### 3.15.3.2 Typical Application

The following figure shows a typical application of the spinlock. A processor locks spinlock0 before executing specific codes, and then unlocks the codes. After the lock is freed, other processors can read or write the data.

Figure 3-40 Spinlock Typical Application Diagram



### 3.15.3.3 Spinlock State Machine

When a processor uses spinlock, it needs to acquire the spinlock status through [SPINLOCK STATUS REG](#).

**Reading operation:** when the return value is 0, it indicates that the spinlock enters the locked status; reading this status bit again can return 1, it indicates that the spinlock is the locked status.

**Writing operation:** when the spinlock is in the locked status, writing 0 can convert the spinlock to the unlocked status, the writing operation for other status is invalid.

The following figure shows the spinlock state machine.

Figure 3-41 Spinlock State Machine



- a) When the spinlock is in the unlocked state, writing 0/1 has no effect;
- b) When the spinlock is in the locked state, writing 0 can convert the corresponding spinlock to the unlocked state;
- c) When the spinlock is in the locked state, writing 1 has no effect;
- d) When the spinlock is in the unlocked state, reading the bit can return 0 (it indicates spinlock enters into the locked state);
- e) When the spinlock is in the locked state, reading the bit can return 1 (it indicates spinlock is in the locked state);
- f) After reset, the spinlock is in the unlock state by default.

### 3.15.4 Programming Guidelines

#### 3.15.4.1 Switching the Status

Follow the steps below to switch the lock status of a spinlock.

- Step 1** When the read value from [SPINLOCKN\\_LOCK\\_REG \(N=0~31\)](#) is 0, the spinlock comes into the locked status.
- Step 2** Execute the application codes, and the status of [SPINLOCK\\_STATUS\\_REG](#) is 1.
- Step 3** Write 0 to [SPINLOCKN\\_LOCK\\_REG \(N=0~31\)](#), the spinlock converts into the unlocked status, and the corresponding spinlock is released.

### 3.15.4.2 Processing the Interrupt

The spinlock generates an interrupt when a lock is freed (the lock status converts from the locked status to the unlocked status).

Follow the steps below to process the interrupt:

- Step 1** Configure the interrupt enable bit of the corresponding spinlock in [SPINLOCK IRQ EN REG](#) to enable the interrupt.
- Step 2** The spinlock generates an interrupt when its status converts from the locked status to the unlocked status, and the corresponding bit of the [SPINLOCK IRQ STA REG](#) turns to 1.
- Step 3** Execute the interrupt handle function and clear the pending bit.

### 3.15.4.3 Taking/Freeing Spinlock

Take the synchronization between CPUX and DSP with Spinlock0 as an example, the CPUX and DSP perform the following steps.

**Figure 3-42 CPUX and DSP Taking/Freeing Spinlock0 Process**



#### CPUX:

- (a) The CPUX initializes Spinlock.
- (b) Check lock register0 (SPINLOCK\_STATUS\_REG0) status. If it is taken, check until CPUX frees spinlock0 and then request to take spinlock0. Otherwise, retry until the lock register0 is taken.
- (c) Execute CPUX critical code.
- (d) After executing CPUX critical code, the CPUX frees spinlock0.

- (e) The CPUX waits for DSP to free spinlock0.

**DSP:**

- If the CPUX has taken spinlock0, the DSP waits for CPUX to free spinlock0.
- The DSP requests to take spinlock0. If it fails, retry until the lock register0 is taken.
- Execute DSP critical code.
- After executing DSP critical code, the DSP frees spinlock0.

The following codes are for reference.

**CPUX****Step 1** CPUX initializes Spinlock

```
put_wvalue(SPINLOCK_BGR_REG,0x00010000);  
put_wvalue(SPINLOCK_BGR_REG,0x00010001);
```

**Step 2** CPUX requests to take spinlock0

```
rdata=readl(SPINLOCK_STATUS_REG0); //Check lock register0 status  
if(rdata != 0) writel(0, SPINLOCK_LOCK_REG0); //If it is taken, check till CPUX frees spinlock0  
rdata=readl(SPINLOCK_LOCK_REG0); //Request to take spinlock0  
if(rdata != 0) rdata=readl(SPINLOCK_LOCK_REG0); //If it fails, retry till lock register0 is taken
```

**-----CPUX critical code section -----****Step 3** CPUX frees spinlock0

```
writel(0, SPINLOCK_LOCK_REG0); //CPUX frees spinlock0
```

**Step 4** CPUX waits for DSP' freeing spinlock0

```
writel(readl(SPINLOCK_STATUS_REG0) == 1); //CPUX waits for DSP' freeing spinlock0
```

**DSP****Step 1** CPUX has taken spinlock0, DSP waits for CPUX' freeing spinlock0

```
while(readl(SPINLOCK_STATUS_REG0) == 1); //DSP waits for CPUX' freeing spinlock0
```

**Step 2** DSP takes spinlock0 and go on

```
rdata=readl(SPINLOCK_LOCK_REG0); //Request to take spinlock0  
if(rdata != 0) rdata=readl(SPINLOCK_LOCK_REG0); //If it fails, retry till lock register0 is taken
```

**-----DSP critical code section -----**

**Step 3 DSP frees spinlock0**

```
writel(0, SPINLOCK_LOCK_REG0); //DSP frees spinlock0
```

**3.15.5 Register List**

| Module Name | Base Address |
|-------------|--------------|
| Spinlock    | 0x03005000   |

| Register Name         | Offset            | Description                        |
|-----------------------|-------------------|------------------------------------|
| SPINLOCK_SYSTATUS_REG | 0x0000            | Spinlock System Status Register    |
| SPINLOCK_STATUS_REG   | 0x0010            | Spinlock Status Register           |
| SPINLOCK_IRQ_EN_REG   | 0x0020            | Spinlock Interrupt Enable Register |
| SPINLOCK_IRQ_STA_REG  | 0x0040            | Spinlock Interrupt Status Register |
| SPINLOCK_LOCKID0_REG  | 0x0080            | Spinlock Lockid0 Register          |
| SPINLOCK_LOCKID1_REG  | 0x0084            | Spinlock Lockid1 Register          |
| SPINLOCK_LOCKID2_REG  | 0x0088            | Spinlock Lockid2 Register          |
| SPINLOCK_LOCKID3_REG  | 0x008C            | Spinlock Lockid3 Register          |
| SPINLOCK_LOCKID4_REG  | 0x0090            | Spinlock Lockid4 Register          |
| SPINLOCK_LOCK_REGN    | 0x0100 + N*0x0004 | Spinlock Register N (N = 0 to 31)  |

**3.15.6 Register Description****3.15.6.1 0x0000 Spinlock System Status Register (Default Value: 0x1000\_0000)**

| Offset: 0x0000 |            |             | Register Name: SPINLOCK_SYSTATUS_REG                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                     |
| 31:30          | /          | /           | /                                                                                                                                                                                                                               |
| 29:28          | R          | 0x1         | LOCKS_NUM<br>Number of lock registers implemented<br>00: This instance has 256 lock registers<br>01: This instance has 32 lock registers<br>10: This instance has 64 lock registers<br>11: This instance has 128 lock registers |
| 27:9           | /          | /           | /                                                                                                                                                                                                                               |

| Offset: 0x0000 |            |             | Register Name: SPINLOCK_SYSTATUS_REG                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 8              | R          | 0x0         | IU0<br>In-Use flag0, covering lock register0-31<br>0: All lock registers 0-31 are in the NotTaken state.<br>1: At least one of the lock register 0-31 is in the Taken state. |
| 7:0            | /          | /           | /                                                                                                                                                                            |

### 3.15.6.2 0x0010 Spinlock Register Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPINLOCK_STATUS_REG                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:0           | R          | 0x0         | LOCK_REG_STATUS<br>SpinLock[i] status<br>0: The Spinlock is free<br>1: The Spinlock is taken |

### 3.15.6.3 0x0020 Spinlock Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPINLOCK_IRQ_EN_REG                                     |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R/W        | 0x0         | LOCK_IRQ_EN<br>SpinLock[i] interrupt enable<br>0: Disable<br>1: Enable |

### 3.15.6.4 0x0040 Spinlock Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: SPINLOCK_IRQ_STA_REG                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:0           | R/W1C      | 0x0         | LOCK_IRQ_STATUS<br>SpinLock[i] interrupt status<br>0: No effect<br>1: Pending<br>Writing 1 clears this bit. |

**3.15.6.5 0x0080 Spinlock Lockid0 Register (Default Value: 0x7777\_7777)**

| Offset: 0x0080 |            |             | Register Name: SPINLOCK_LOCKIN0_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID0                             |

**3.15.6.6 0x0084 Spinlock Lockid1 Register (Default Value: 0x7777\_7777)**

| Offset: 0x0084 |            |             | Register Name: SPINLOCK_LOCKIN1_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID1                             |

**3.15.6.7 0x0088 Spinlock Lockid2 Register (Default Value: 0x7777\_7777)**

| Offset: 0x0088 |            |             | Register Name: SPINLOCK_LOCKIN2_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID2                             |

**3.15.6.8 0x008C Spinlock Lockid3 Register (Default Value: 0x7777\_7777)**

| Offset: 0x008C |            |             | Register Name: SPINLOCK_LOCKIN3_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID3                             |

**3.15.6.9 0x0090 Spinlock Lockid4 Register (Default Value: 0x7777\_7777)**

| Offset: 0x0090 |            |             | Register Name: SPINLOCK_LOCKIN4_REG |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:0           | R          | 0x77777777  | LOCKID4                             |

**3.15.6.10 0x0100 + N\*0x04 Spinlock Register N (N = 0 to 31) (Default Value: 0x0000\_0000)**

| Offset: 0x0100 + N*0x0004 (N = 0 to 31) |            |             | Register Name: SPINLOCKN_LOCK_REG                                                                                                                                                                                                                                                                          |
|-----------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                     | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                |
| 31:1                                    | /          | /           | /                                                                                                                                                                                                                                                                                                          |
| 0                                       | R/W        | 0x0         | TAKEN<br>Lock State<br>Read 0x0: The lock was previously Not Taken (free). The requester is granted the lock.<br>Write 0x0: Set the lock to Not Taken (free).<br>Read 0x1: The lock was previously Taken. The requester is not granted the lock and must retry.<br>Write 0x1: No update to the lock value. |

## 3.16 RTC

### 3.16.1 Overview

The Real Time Clock (RTC) is used to implement time counter and timing wakeup functions. The RTC can display the year, month, day, week, hour, minute, second in real time. The RTC has the independent power to continue to work in system power-off.

The RTC has the following features:

- Provides a 16-bit counter for counting day, 5-bit counter for counting hour, 6-bit counter for counting minute, 6-bit counter for counting second
- External connect a 32.768 kHz low-frequency oscillator for count clock
- Timer frequency is 1 kHz
- Configurable initial value by software anytime
- Supports timing alarm, and generates interrupt and wakeup the external devices
- Eight 32-bit user registers for storing power-off information



#### CAUTION

The register configuration of RTC is AHB bus, it only can support word operation, not byte operation and half-word operation.

### 3.16.2 Block Diagram

The following figure shows the block diagram of the RTC.

**Figure 3-43 RTC Block Diagram**

### 3.16.3 Functional Description

#### 3.16.3.1 External Signals

**Table 3-19 RTC External Signals**

| Signal  | Description                                    |
|---------|------------------------------------------------|
| X32KIN  | 32.768 kHz oscillator input                    |
| X32KOUT | 32.768 kHz oscillator output                   |
| VCC-RTC | RTC high voltage, generated via external power |

### 3.16.3.2 Typical Application

Figure 3-44 RTC Application Diagram



### 3.16.3.3 Clock Tree

The following figure shows the clock tree of the RTC.

Figure 3-45 RTC Clock Tree



- **LOSC**

The LOSC has 2 clock sources: internal RC, external low frequency crystal. The LOSC selects the internal RC by default, when the system starts, the LOSC can select by software the external low frequency crystal to provide much accuracy clock. The clock accurate of the LOSC is related to the accurate of the external low frequency crystal. Usually select 32.768 kHz crystal with  $\pm 20$  ppm frequency tolerance. When using internal RC, the clock can be changed by changing division ratio. When using external clock, the clock cannot be changed.

- **RTC**

The clock sources of RTC can be selected by related switches, including 32K divided by internal 16 MHz RC, 32K divided by external DCXO, and external 32.768 kHz crystal.

- **System 32K**

The clock sources of system 32K are from external 32.768 kHz crystal and 32K divided by the internal 16 MHz RC.

- **RTC\_32K\_FANOUT**

The clock source of RTC\_32K\_FANOUT can select CLK32K, external 32.768 kHz crystal or 32K divided by external DCXO.

### 3.16.3.4 Real Time Clock

Figure 3-46 RTC Counter



The 1K counter adds 1 on each rising edge of the clock. When the clock number reaches 0xFF, 1K counter starts to count again from 0, and the second counter adds 1. The step structure of 1 kHz counter is as follows.

**Figure 3-47 RTC 1 kHz Counter Step Structure.**

According to above implementation, the changing range of each counter is as follows.

**Table 3-20 RTC Counter Changing Range**

| Counter | Range                                                                                      |
|---------|--------------------------------------------------------------------------------------------|
| Second  | 0 to 59                                                                                    |
| Minute  | 0 to 59                                                                                    |
| Hour    | 0 to 23                                                                                    |
| Day     | 0 to 65535 (The year, month, day need be transformed by software according to day counter) |

**CAUTION**

Because there is no error correction mechanism in the hardware, note that each counter configuration should not exceed a reasonable counting range.

### 3.16.3.5 Alarm 0

The principle of alarm0 is a comparator. When RTC timer reaches the scheduled time, the RTC generates the interrupt, or outputs low level signal by NMI pin to wakeup power management chip.

The RTC only generates one interrupt when RTC timer reached the scheduled day, hour, minute and second counter, then the RTC needs to be set a new scheduled time, the next interrupt can be generated.

### 3.16.3.6 Power-off Information Storage

The RTC provides eight 32-bit general purpose register to store power-off information.

Because VCC-RTC always holds non-power-off state after VCC-RTC cold starts, when the system is in shutdown or standby scene, the CPU can judge software process by the storing information.

### 3.16.3.7 RTC\_VIO

The RTC module has a LDO, the input source of the LDO is VCC\_RTC, the output of the LDO is RTC\_VIO, the value of RTC\_VIO is adjustable, the RTC\_VIO is mainly used for internal digital logic.

### 3.16.3.8 RC Calibration Usage Scenario

- Power-on: Select non-accurate 32K divided by internal RC.
- Normal scenario: Select external accurate 32K, or external calibrated 32K.
- Standby or power-off scenario: Select external accurate 32K, or external calibrated 32K.

## 3.16.4 Programming Guidelines

### 3.16.4.1 RTC Clock Control

- Step 1** Select clock source: Select clock source by the bit0 of [LOSC\\_CTRL\\_REG](#), the clock source is the internal RC oscillator by default. When the system starts, the clock source can be switched to the external 32K oscillator by software.
- Step 2** Auto switch: After enabled the bit[15:14] of [LOSC\\_CTRL\\_REG](#), the RTC automatically switches clock source to the internal oscillator when the external crystal could not output waveform, the switch status can query by the bit[1] of [LOSC\\_AUTO\\_SWT\\_STA\\_REG](#).



#### NOTE

If only configuring the bit[15] of [LOSC\\_CTRL\\_REG](#), the clock source status bit cannot be changed after the auto switch is valid, because the two functions are independent.

Here is the basic code samples.

```
Write (0x16aa4000,LOSC_Ctrl); //Write key field  
Write (0x16aa4001,LOSC_Ctrl); //Select the external 32K clock
```

### 3.16.4.2 RTC Calendar

**Step 1** Write time initial value: Write the current time to [RTC DAY REG](#) and [RTC HH\\_MM\\_SS REG](#).

**Step 2** After updated time, the RTC restarts to count again. The software can read the current time anytime.



#### NOTE

- The RTC can only provide day counter, so the current day counter need be converted to year, month, day and week by software.
- Ensure the bit[8:7] of LOSC\_CTRL\_REG is 0 before the next time configuration is performed.

Here is the basic code samples.

For example: set time to 21st, 07:08:09 and read it.

```
RTC_DAY_REG = 0x00000015;
```

```
RTC_HH_MM_SS_REG = 0x00070809; //0000 0000 000|0 0000(Hour) 00|00 0000(Minute) 00|00 0000(Second)
```

```
Read (RTC_DAY_REG);
```

```
Read (RTC_HH_MM_SS_REG);
```

### 3.16.4.3 Alarm0

**Step 1** Enable alram0 interrupt by writing [ALARMO IRQ\\_EN](#).

**Step 2** Set the counter comparator, write the count-down day, hour, minute, second number to [ALARMO DAY SET REG](#) and [ALARMO HH-MM-SS SET REG](#).

**Step 3** Enable alarm0 function by writing [ALARMO ENABLE REG](#), then the software can query alarm count value in real time by [ALARMO DAY SET REG](#) and [ALARMO HH-MM-SS SET REG](#). When the setting time reaches, [ALARMO IRQ STA REG](#) is set to 1 to generate interrupt.

**Step 4** After enter the interrupt process, write [ALARMO IRQ STA REG](#) to clear the interrupt pending, and execute the interrupt process.

**Step 5** Resume the interrupt and continue to execute the interrupted process.

**Step 6** The power-off wakeup is generated via SoC hardware and PMIC, the software only needs to set the pending condition of alarm0, and set [ALARM CONFIG REG](#) to 1.

### 3.16.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| RTC         | 0x07090000   |

| Register Name             | Offset          | Description                                      |
|---------------------------|-----------------|--------------------------------------------------|
| LOSC_CTRL_REG             | 0x0000          | Low Oscillator Control Register                  |
| LOSC_AUTO_SWT_STA_REG     | 0x0004          | LOSC Auto Switch Status Register                 |
| INTOSC_CLK_PRESCAL_REG    | 0x0008          | Internal OSC Clock Pre-scalar Register           |
| RTC_DAY_REG               | 0x0010          | RTC Year-Month-Day Register                      |
| RTC_HH_MM_SS_REG          | 0x0014          | RTC Hour-Minute-Second Register                  |
| ALARMO_DAY_SET_REG        | 0x0020          | Alarm 0 Day Setting Register                     |
| ALARMO_CUR_VLU_REG        | 0x0024          | Alarm 0 Counter Current Value Register           |
| ALARMO_ENABLE_REG         | 0x0028          | Alarm 0 Enable Register                          |
| ALARMO_IRQ_EN             | 0x002C          | Alarm 0 IRQ Enable Register                      |
| ALARMO_IRQ_STA_REG        | 0x0030          | Alarm 0 IRQ Status Register                      |
| ALARM_CONFIG_REG          | 0x0050          | Alarm Configuration Register                     |
| 32K_FOUT_CTRL_GATING_REG  | 0x0060          | 32K Fanout Control Gating Register               |
| GP_DATA_REG               | 0x0100 + N*0x04 | General Purpose Register (N=0 to 7)              |
| FBOOT_INFO_REG0           | 0x0120          | Fast Boot Information Register0                  |
| FBOOT_INFO_REG1           | 0x0124          | Fast Boot Information Register1                  |
| DCXO_CTRL_REG             | 0x0160          | DCXO Control Register                            |
| RTC_VIO_REG               | 0x0190          | RTC_VIO Regulation Register                      |
| IC_CHAR_REG               | 0x01F0          | IC Characteristic Register                       |
| VDD_OFF_GATING_CTRL_REG   | 0x01F4          | VDD Off Gating Control Register                  |
| EFUSE_HV_PWR SWT_CTRL_REG | 0x0204          | Efuse High Voltage Power Switch Control Register |
| RTC_SPI_CLK_CTRL_REG      | 0x0310          | RTC SPI Clock Control Register                   |



#### NOTE

The offset addresses less than 0x0300 are in VDD\_RTC power domain, and the offset addresses large than or equal to 0x300 are in VDD\_SYS power domain.

### 3.16.6 Register Description

#### 3.16.6.1 0x0000 LOSC Control Register (Default Value: 0x0000\_4010)

| Offset:0x0000 |            |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                                                                                                          |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                           |
| 31:16         | W          | 0x0         | KEY_FIELD<br>Key Field<br>This field should be filled with 0x16AA, and then the bit0 and bit1 can be written with the new value.                                                                                                                                                                                                                                      |
| 15            | R/W        | 0x0         | LOSC_AUTO_SWT_FUNCTION<br>LOSC auto switch function disable<br>0: Enable<br>1: Disable                                                                                                                                                                                                                                                                                |
| 14            | R/W        | 0x1         | LOSC_AUTO_SWT_32K_SEL_EN<br>LOSC auto switch 32K clk source select enable<br>0: Disable. When the losc loses, the 32k clk source will not change to RC<br>1: Enable. When the losc loses, the 32k clk source will change to RC (LOSC_SRC_SEL will be changed from 1 to 0)                                                                                             |
| 13:9          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                     |
| 8             | R/W        | 0x0         | RTC_HHMMSS_ACCE<br>RTC Hour Minute Second access<br>After writing the RTC HH-MM-SS Register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC HH-MM-SS Register, the RTC HH-MM-SS Register will be refreshed for at most one second.<br><b>Note: Make sure that the bit is 0 for time configuration.</b> |
| 7             | R/W        | 0x0         | RTC_DAY_ACCE<br>RTC DAY access<br>After writing the RTC DAY register, this bit is set and it will be cleared until the real writing operation is finished.<br>After writing the RTC DAY register, the DAY register will be refreshed for at most one second.<br><b>Note: Make sure that the bit is 0 for time configuration.</b>                                      |
| 6:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                     |
| 4             | R/W        | 0x1         | EXT_LOSC_EN<br>External 32.768 kHz Crystal Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                          |

| Offset:0x0000 |            |             | Register Name: LOSC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:2           | R/W        | 0x0         | <p>EXT_LOSC_GSM<br/>External 32.768 kHz Crystal GSM<br/>00: Low<br/>01: /<br/>10: /<br/>11: High<br/>When GSM is changed, the 32K oscillation circuit will arise transient instability. If the autoswitch function (bit 15) is enabled, 32K changes to RC16M with certain probability. The GSM can influence the time of 32K starting oscillation, the more the GSM, the shorter the time of starting oscillation. So modifying GSM is not recommended.<br/>If you need to modify the GSM, firstly disable the auto switch function (bit 15), with a delay of 50 us, then change the GSM, the 32K clock source is changed to external clock.</p> |
| 1             | R/W        | 0x0         | <p>RTC_SRC_SEL<br/>RTC_TIMER Clock Source Select<br/>0: LOSC_SRC<br/>1: 24MDIV32K<br/>Before switching the bit, make sure that the 24MDIV32K function is enabled, that is, the bit16 of the <a href="#">32K Fanout Control Register</a> is 1.</p>                                                                                                                                                                                                                                                                                                                                                                                                |
| 0             | R/W        | 0x0         | <p>LOSC_SRC_SEL<br/>LOSC Clock Source Select<br/>0: Low frequency clock from 16M RC<br/>1: External 32.768 kHz OSC</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



#### NOTE

If the bit[8:7] of LOSC\_CTRL\_REG is set, the RTC HH-MM-SS, DD and ALARM DD-HH-MM-SS register cannot be written.

### 3.16.6.2 0x0004 LOSC Auto Switch Status Register (Default Value: 0x0000\_0000)

| Offset:0x0004 |            |             | Register Name: LOSC_AUTO_SWT_STA_REG                                                                                                                                                       |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31:3          | /          | /           | /                                                                                                                                                                                          |
| 2             | R          | 0x0         | <p>EXT_LOSC_STA<br/>Work only when the auto switch function is enabled.<br/>0: External 32.768 kHz OSC work normally<br/>1: External 32.768 kHz OSC work abnormally</p>                    |
| 1             | R/W1C      | 0x0         | <p>LOSC_AUTO_SWT_PEND<br/>LOSC auto switch pending<br/>0: No effect<br/>1: Auto switch pending, it means LOSC_SRC_SEL is changed from 1 to 0.<br/>Setting 1 to this bit will clear it.</p> |
| 0             | R          | 0x0         | <p>LOSC_SRC_SEL_STA<br/>Checking LOSC clock source status<br/>0: Low frequency clock from 16M RC<br/>1: External 32.768 kHz OSC</p>                                                        |

### 3.16.6.3 0x0008 Internal OSC Clock Prescalar Register (Default Value: 0x0000\_000F)

| Offset:0x0008 |            |             | Register Name: INTOSC_CLK_PRESCAL_REG                                                                                                                                                  |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:5          | /          | /           | /                                                                                                                                                                                      |
| 4:0           | R/W        | 0xF         | <p>INTOSC_32K_CLK_PRESCAL<br/>Internal OSC 32K Clock Prescalar value N.<br/>The clock output = Internal RC/32/N.</p> <p>00000: 1<br/>00001: 2<br/>00002: 3<br/>.....<br/>11111: 32</p> |

### 3.16.6.4 0x0010 RTC Year-Month-DAY Register (Default Value: UDF)

| Offset:0x0010 |            |             | Register Name: RTC_DAY_REG               |
|---------------|------------|-------------|------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                              |
| 31:16         | /          | /           | /                                        |
| 15:0          | R/W        | UDF         | DAY<br>Set Day<br>Range from 0 to 65535. |

### 3.16.6.5 0x0014 RTC Hour-Minute-Second Register (Default Value: UDF)

| Offset:0x0014 |            |             | Register Name: RTC_HH_MM_SS_REG             |
|---------------|------------|-------------|---------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                 |
| 31:21         | /          | /           | /                                           |
| 20:16         | R/W        | UDF         | HOUR<br>Set hour<br>Range from 0 to 23.     |
| 15:14         | /          | /           | /                                           |
| 13:8          | R/W        | UDF         | MINUTE<br>Set minute<br>Range from 0 to 59. |
| 7:6           | /          | /           | /                                           |
| 5:0           | R/W        | UDF         | SECOND<br>Set second<br>Range from 0 to 59. |

### 3.16.6.6 0x0020 Alarm 0 Day Setting Register (Default Value: 0x0000\_0000)

| Offset:0x0020 |            |             | Register Name: ALARM0_DAY_SET_REG                  |
|---------------|------------|-------------|----------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                        |
| 31:16         | /          | /           | /                                                  |
| 15:0          | R/W        | 0x0         | ALARM0_COUNTER<br>Alarm 0 Counter is based on Day. |

### 3.16.6.7 0x0024 Alarm 0 Counter Current Value Register (Default Value: UDF)

| Offset:0x0024 |            |             | Register Name: ALARM0_CUR_VLU_REG               |
|---------------|------------|-------------|-------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                     |
| 31:21         | /          | /           | /                                               |
| 20:16         | R/W        | UDF         | HOUR<br>Current hour<br>Range from 0 to 23.     |
| 15:14         | /          | /           | /                                               |
| 13:8          | R/W        | UDF         | MINUTE<br>Current minute<br>Range from 0 to 59. |
| 7:6           | /          | /           | /                                               |
| 5:0           | R/W        | UDF         | SECOND<br>Current second<br>Range from 0 to 59. |

### 3.16.6.8 0x0028 Alarm 0 Enable Register (Default Value: 0x0000\_0000)

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

### 3.16.6.9 0x002C Alarm 0 IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:0x002C |            |             | Register Name: ALARM0_IRQ_EN                                   |
|---------------|------------|-------------|----------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                    |
| 31:1          | /          | /           | /                                                              |
| 0             | R/W        | 0x0         | ALARM0_IRQ_EN<br>Alarm 0 IRQ Enable<br>0: Disable<br>1: Enable |

### 3.16.6.10 0x0030 Alarm 0 IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:0x0030 |            |             | Register Name: ALARM0_IRQ_STA_REG                                                                                                                                                                          |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                |
| 31:1          | /          | /           | /                                                                                                                                                                                                          |
| 0             | R/W1C      | 0x0         | ALARM0_IRQ_PEND<br>Alarm 0 IRQ Pending bit<br>0: No effect<br>1: Pending, alarm 0 counter value is reached<br>If alarm 0 irq enable is set to 1, the pending bit will be sent to the interrupt controller. |

### 3.16.6.11 0x0050 Alarm Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0050 |            |             | Register Name: ALARM_CONFIG_REG                                                                                             |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                 |
| 31:1          | /          | /           | /                                                                                                                           |
| 0             | R/W        | 0x0         | ALARM_WAKEUP<br>Configuration of alarm wake up output.<br>0: Disable alarm wake up output<br>1: Enable alarm wake up output |

### 3.16.6.12 0x0060 32K Fanout Control Gating Register (Default Value: 0x0000\_0000)

| Offset:0x0060 |            |             | Register Name: 32K_FOUT_CTRL_GATING_REG                                                                                                                     |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31:17         | /          | /           | /                                                                                                                                                           |
| 16            | R/W        | 0x0         | HOSC_TO_32K_DIVIDER_ENABLE<br>HOSC to 32k divider enable<br>0: Disable the hosc 24M to 32K divider circuit<br>1: Enable the hosc 24M to 32K divider circuit |
| 15:3          | /          | /           | /                                                                                                                                                           |
| 2:1           | R/W        | 0x0         | LOSC_OUT_SRC_SEL<br>LOSC output source select<br>00: RTC_32K (select by RC_CLK_SRC_SEL & LOSC_SRC_SEL)<br>01: LOSC<br>10: HOSC divided 32K                  |

| Offset:0x0060 |            |             | Register Name: 32K_FOUT_CTRL_GATING_REG                                                                                                                                                                   |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 0             | R/W        | 0x0         | <p>32K_FANOUT_GATING</p> <p>LOSC out gating enable</p> <p>Configuration of LOSC output, and there is no LOSC output by default.</p> <p>0: Mask LOSC output gating</p> <p>1: Enable LOSC output gating</p> |

### 3.16.6.13 0x0100+N\*0x0004 General Purpose Register (Default Value: 0x0000\_0000)

| Offset:0x0100+N*0x0004 (N=0 to 7) |            |             | Register Name: GP_DATA_REGN       |
|-----------------------------------|------------|-------------|-----------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                       |
| 31:0                              | R/W        | 0x0         | <p>GP_DATA</p> <p>Data [31:0]</p> |



#### NOTE

General purpose register 0 to 7 value can be stored if the RTC-VIO is larger than 0.7 V.

### 3.16.6.14 0x0120 Fast Boot Information Register0 (Default Value: 0x0000\_0000)

| Offset:0x0120 |            |             | Register Name: FBOOT_INFO_REG0                                                               |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                  |
| 31:0          | R/W        | 0x0         | <p>FBOOT_INFO0</p> <p>Fast Boot info</p> <p>Fast Boot Information 0, refer to BROM spec.</p> |

### 3.16.6.15 0x0124 Fast Boot Information Register1 (Default Value: 0x0000\_0000)

| Offset:0x0124 |            |             | Register Name: FBOOT_INFO_REG1                                                               |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                  |
| 31:0          | R/W        | 0x0         | <p>FBOOT_INFO1</p> <p>Fast Boot info</p> <p>Fast Boot Information 1, refer to BROM spec.</p> |

### 3.16.6.16 0x0160 DCXO Control Register (Default Value: 0x883F\_10F7)

| Offset:0x0160 |            |             | Register Name: DCXO_CTRL_REG                                                                                                                             |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31            | R/W        | 0x1         | CLK_REQ_ENB<br>Clock REQ enable<br>0: Enable DCXO wake up function<br>1: Disable DCXO wake up function                                                   |
| 30:28         | /          | /           | /                                                                                                                                                        |
| 27:24         | R/W        | 0x8         | DCXO_ICTRL<br>DCXO current control value                                                                                                                 |
| 23            | /          | /           | /                                                                                                                                                        |
| 22:16         | R/W        | 0x3F        | DCXO_TRIM<br>DCXO cap array value<br>The capacity cell is 55 fF.                                                                                         |
| 15:13         | /          | /           | /                                                                                                                                                        |
| 12:8          | R/W        | 0x10        | DCXO_BG<br>DCXO bandgap output voltage                                                                                                                   |
| 7             | R/W        | 0x1         | DCXO_LDO_INRUSHB<br>DCXO LDO driving capacity signal, active high                                                                                        |
| 6             | R/W        | 0x1         | XTAL_MODE<br>Xtal mode enable signal, active high<br>0: For external clk input mode<br>1: For normal mode                                                |
| 5:4           | R/W        | 0x3         | DCXO_RFCLK_ENHANCE<br>DCXO rfclk enhance<br>Enhance driving capacity of output OUT_RF_REFCLK, 0x0 for 5 pF, 0x1 for 10 pF, 0x2 for 15 pF, 0x3 for 20 pF. |
| 3             | /          | /           | /                                                                                                                                                        |
| 2             | R/W        | 0x1         | RSTO_DLY_SEL<br>For Debug Use Only.<br>It cannot configure to 0 in normal state.                                                                         |
| 1             | R/W        | 0x1         | DCXO_EN<br>DCXO enable<br>1: Enable<br>0: Disable                                                                                                        |

| Offset:0x0160 |            |             | Register Name: DCXO_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0             | R/W        | 0x1         | <p>CLK16M_RC_EN</p> <p>1: Enable<br/>0: Disable</p> <p>The related register configuration is necessary to ensure the reset debounce circuit has a stable clock source.</p> <p>The first time SoC starts up, by default, the reset debounce circuit of SoC uses 32K divided by RC16M. In power-off, software reads the related bit to ensure whether EXT32K is working normally, if it is normal, first switch the clock source of debounce circuit to EXT32K, then close RC16M.</p> <p>Without EXT32K scenario or external RTC scenario, software confirms firstly whether EXT32K is working normally before switching, or software does not close RC16M.</p> |

### 3.16.6.17 0x0190 RTC\_VIO Regulation Register (Default Value: 0x0000\_0004)

| Offset:0x0190 |            |             | Register Name:RTC_VIO_REG                                                                                                                                                                                                                                                                                                                                      |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                    |
| 31:5          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                              |
| 4             | R/W        | 0x0         | <p>V_SEL</p> <p>VDD Select</p> <p>0: Resistance divider<br/>1: Band-gap</p>                                                                                                                                                                                                                                                                                    |
| 3             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                              |
| 2:0           | R/W        | 0x4         | <p>RTC_VIO_REGU</p> <p>RTC_VIO Voltage Select</p> <p>The RTC-VIO is provided power for RTC digital part.</p> <p>These bits are useful for regulating the RTC_VIO from 0.65 V to 1.3 V.</p> <p>000: 1.0 V<br/>001: 0.65 V (the configuration can cause RTC reset)<br/>010: 0.7 V<br/>011: 0.8 V<br/>100: 0.9 V<br/>101: 1.1 V<br/>110: 1.2 V<br/>111: 1.3 V</p> |

### 3.16.6.18 0x01F0 IC Characteristic Register (Default Value: 0x0000\_0000)

| Offset:0x01F0 |            |             | Register Name: IC_CHARA_REG                                                                                                        |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:16         | R/W        | 0x0         | KEY_FIELD<br>Key Field<br>The field should be written as 0x16AA. Writing any other value in this field aborts the write-operation. |
| 15:0          | R/W        | 0x0         | ID_DATA<br>Return 0x16AA only if the KEY_FIELD is set as 0x16AA when read those bits, otherwise return 0x0.                        |

### 3.16.6.19 0x01F4 VDD Off Gating Control Register (Default Value: 0x0000\_0041)

| Offset:0x01F4 |            |             | Register Name: VDD_OFF_GATING_CTRL_REG                                                                                                                                                                                                                                                                                                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                          |
| 31:16         | W          | 0x0         | KEY_FIELD<br>Key Field<br>This field should be filled with 0x16AA, and then the bit 15 can be configured.                                                                                                                                                                                                                                                                            |
| 15            | WAC        | 0x0         | PWROFF_GAT_RTC_CFG (For Debug Use Only)<br>Power off gating control signal<br>When use vdd_sys to RTC isolation software control, write this bit to 1. It will only be cleared by resetb release.                                                                                                                                                                                    |
| 14:12         | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:4          | R/W        | 0x4         | VCCIO_DET_SPARE<br>Bit[7:5]: Reserved, default=0<br>Bit[4]: Bypass debounce circuit, default=0<br>Bit[3]: Enable control, default=0<br>0: Disable VCC-IO detection<br>1: Force the detection output<br>Bit[2:0]: Gear adjustment<br>000: Detection threshold is 2.5 V<br>001: Detection threshold is 2.6 V<br>010: Detection threshold is 2.7 V<br>011: Detection threshold is 2.8 V |

| Offset:0x01F4 |            |             | Register Name: VDD_OFF_GATING_CTRL_REG                                                                                                                                                                                                                                                                                                                                                  |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                             |
|               |            |             | <p>100: Detection threshold is 2.9 V (default)<br/>           101: Detection threshold is 3 V<br/>           110: N/A<br/>           111: N/A</p> <p>Note: Since VCC_RTC is the reference voltage for VCCIO power-down detection, in non-battery solutions, VCC_RTC will be powered down when the system shuts down. In this condition, VCCIO_DET needs to be set to 2.9V or above.</p> |
| 3:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                       |
| 0             | R/W        | 0x1         | <p>VCCIO_DET_BYPASS_EN<br/>           0: not bypass<br/>           1: bypass</p>                                                                                                                                                                                                                                                                                                        |

### 3.16.6.20 0x0204 Efuse High Voltage Power Switch Control Register (Default Value: 0x0000\_0000)

| Offset:0x0204 |            |             | Register Name: EFUSE_HV_PWR SWT_CTRL_REG                                                                        |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                     |
| 31:1          | /          | /           | /                                                                                                               |
| 0             | R/W        | 0x0         | <p>EFUSE_1.8V_POWER_SWITCH_CONTROL<br/>           1: Open power switch<br/>           0: Close power switch</p> |

### 3.16.6.21 0x0310 RTC SPI Clock Control Register (Default Value: 0x0000\_0009)

| Offset:0x0310 |            |             | Register Name: RTC_SPI_CLK_CTRL_REG                                                                                                                                                                                                                                                                                  |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                          |
| 31            | R/W        | 0x0         | <p>RTC Reg CFG SPI Clock Gating<br/>           0: Gating<br/>           1: Not Gating</p> <p>Before configuring RTC register, the clock divider of SPI needs be configured firstly, then clock gating needs be enabled.</p> <p><b>Note: Frequency division and clock gating can not be set at the same time.</b></p> |
| 30:5          | /          | /           | /                                                                                                                                                                                                                                                                                                                    |
| 4:0           | R/W        | 0x9         | RTC Reg CFG SPI Clock Divider: M                                                                                                                                                                                                                                                                                     |

| Offset:0x0310 |            |             | Register Name: RTC_SPI_CLK_CTRL_REG                                                                                                                                                                                                                     |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                             |
|               |            |             | <p>Actual SPI Clock = AHBS1/(M+1), (0 to 15)</p> <p>The default frequency of AHBS1 is 200 MHz, and the default frequency of SPI Clock is 20 MHz.</p> <p><b>Note:</b> The SPI clock can not exceed 50 MHz, or else the RTC register may be abnormal.</p> |

## Contents

|       |                          |     |
|-------|--------------------------|-----|
| 4     | Video and Graphics ..... | 417 |
| 4.1   | DE .....                 | 417 |
| 4.2   | DI .....                 | 419 |
| 4.3   | G2D.....                 | 420 |
| 4.4   | Video Decoding.....      | 421 |
| 4.4.1 | Overview .....           | 421 |
| 4.4.2 | Block Diagram .....      | 422 |
| 4.5   | Video Encoding .....     | 423 |
| 4.5.1 | Overview .....           | 423 |
| 4.5.2 | Block Diagram .....      | 423 |

## Figures

|                                              |     |
|----------------------------------------------|-----|
| Figure 4-1 DE Block Diagram.....             | 418 |
| Figure 4-2 Video Decoding Block Diagram..... | 422 |
| Figure 4-3 JPEG Block Diagram .....          | 424 |

## 4 Video and Graphics

### 4.1 DE

The Display Engine (DE) is a hardware composer to transfer image layers from a local bus or a video buffer to the LCD interface. The DE supports four overlay windows to blend, and supports image post-processing in the video channel. The block diagram of DE is shown in Figure 4-1.

The DE has the following features:

- Output size up to 2048 x 2048
- Two alpha blending channels for main display, one channel for aux display
- Four overlay layers in each channel, and has a independent scaler
- Potter-duff compatible blending operation
- Supports input format Semi-planar YUV422/YUV420/YUV411 and Planar YUV422/YUV420/YUV411, ARGB8888/XRGB8888/RGB888/ARGB4444/ARGB1555/RGB565/palette
- Supports SmartColor2.0 for excellent display experience
  - Adaptive detail/edge enhancement
  - Adaptive color enhancement
  - Adaptive contrast enhancement and fresh tone rectify
- Supports write back for aux display

**Figure 4-1 DE Block Diagram**

## 4.2 DI

The De-interlacer (DI) converts the interlaced input video frame to progressive video frame.

The DI has the following features:

- Supports YUV420 (Planar/NV12/NV21) and YUV422 (Planar/NV16/NV61) data format
- Supports video resolution from 32 x 32 to 2048 x 1280 pixel
- Supports Inter-field interpolation/motion adaptive de-interlace method
- Performance: module clock 600M for 1080p@60Hz YUV420

## 4.3 G2D

The Graphic 2D (G2D) engine is hardware accelerator for 2D graphic.

The G2D has the following features:

- Supports layer size up to 2048 x 2048 pixels
- Supports pre-multiply alpha image data
- Supports color key
- Supports two pipes Porter-Duff alpha blending
- Supports multiple video formats 4:2:0, 4:2:2, 4:1:1 and multiple pixel formats (8/16/24/32 bits graphics layer)
- Supports memory scan order option
- Supports any format convert function
- Supports 1/16x to 32x resize ratio
- Supports 32-phase 8-tap horizontal anti-alias filter and 32-phase 4-tap vertical anti-alias filter
- Supports window clip
- Supports FillRectangle, BitBlit, StretchBlit and MaskBlit
- Supports horizontal and vertical flip, clockwise 0/90/180/270 degree rotate for normal buffer
- Supports horizontal flip, clockwise 0/90/270 degree rotate for LBC buffer

## 4.4 Video Decoding

### 4.4.1 Overview

The Video Decoding consists of Video Control Firmware (VCF) running on ARM processor and embedded hardware Video Engine (VE). VCF gets the bitstream from topper software, parses bitstream, invokes the Video Engine, and generates the decoding image sequence. The decoder image sequence is transmitted by the video output controller to the display device under the control of the topper software.

The Video Decoding has the following features:

- Supports H.265 MP@L4.1
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports H.264 BP/MP/HP@L4.2
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports H.263 BP
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports MPEG-4 SP/ASP L5
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports MPEG-2 MP/HL
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports MPEG-1 MP/HL
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports JPEG/Xvid/Sorenson Spark
  - Maximum video resolution: 1920 x 1080
  - Maximum decoding rate: 60 Mbit/s, 1080p@60fps
- Supports MJPEG

- Maximum video resolution: 1920 x 1080
- Maximum decoding rate: 60 Mbit/s, 1080p@30fps

#### 4.4.2 Block Diagram

The functional block diagram of the Video Decoding is as follows.

Figure 4-2 Video Decoding Block Diagram



## 4.5 Video Encoding

### 4.5.1 Overview

The Video Encoding supports JPEG/MJPEG encoding (JPGE).

The JPGE is a high-performance JPEG encoder implemented by using hardware. It supports 64-megapixel snapshot or HD MJPEG encoding.

The JPGE has the following features:

- Supports ISO/IEC 10918-1 (CCITT T.81) baseline process (DCT sequential) encoding
- Encodes the pictures in the chrominance sampling format of YCbCr4:2:0 and YCbCr4:2:2
- Supports multiple input picture formats:
  - Semi-planar YCbCr4:2:0
  - Semi-planar YCbCr4:2:2
- Supports JPEG encoding with the performance of 1080p@60fps
- Supports configurable picture resolutions
  - Minimum picture resolution: 192 x 96
  - Maximum picture resolution: 4096 x 4096
- Supports the picture width or height step of 8
- Supports configurable quantization tables for the Y component, Cb component and Cr component respectively
- Supports OSD front-end overlapping
  - OSD overlaying before encoding for a maximum of 16 regions
  - OSD overlaying with any size and at any position (within the size and position range of the picture)
  - 16-level alpha blending
  - OSD overlaying control (enabled or disabled)
- Supports the color-to-gray function
- Supports the MJPEG output bit rate ranging from 2 kbit/s to 60 Mbit/s

### 4.5.2 Block Diagram

The functional block diagram of the JPGE is as follows.

Figure 4-3 JPGE Block Diagram



The JPGE realizes various protocol processing with large computation such as OSD, level shift, DCT, quantization, scanning, VLC encoding, and stream generation. The ARM software completes the encoding control processing such as quantization table configuration and interrupt processing.

Before the JPGE starts encoding, the software allocates two types of buffers mainly in the external DDR SDRAM:

- **Input picture buffer**

The JPGE reads the source pictures to be encoded from this buffer during encoding. This buffer is generally written by the Video Input Port module.

- **Stream buffer**

This buffer stores encoded streams. The JPGE writes streams to this buffer during encoding. This buffer is read by software.

# Contents

|       |                                    |     |
|-------|------------------------------------|-----|
| 5     | Video Output Interfaces.....       | 428 |
| 5.1   | TCON LCD .....                     | 428 |
| 5.1.1 | Overview .....                     | 428 |
| 5.1.2 | Block Diagram .....                | 429 |
| 5.1.3 | Functional Description .....       | 429 |
| 5.1.4 | Programming Guidelines.....        | 441 |
| 5.1.5 | Register List.....                 | 448 |
| 5.1.6 | Register Description .....         | 450 |
| 5.2   | TCON TV .....                      | 483 |
| 5.2.1 | Overview .....                     | 483 |
| 5.2.2 | Functional Description .....       | 483 |
| 5.2.3 | Register List.....                 | 483 |
| 5.2.4 | Register Description .....         | 484 |
| 5.3   | TV Encoder .....                   | 496 |
| 5.3.1 | Overview .....                     | 496 |
| 5.3.2 | Block Diagram .....                | 496 |
| 5.3.3 | Functional Description .....       | 496 |
| 5.3.4 | Programming Guidelines.....        | 498 |
| 5.3.5 | Register List.....                 | 499 |
| 5.3.6 | TVE_TOP Register Description ..... | 501 |
| 5.3.7 | TVE Register Description .....     | 505 |
| 5.4   | MIPI DSI.....                      | 525 |
| 5.4.1 | Overview .....                     | 525 |

# Figures

|                                                              |     |
|--------------------------------------------------------------|-----|
| Figure 5-1 TCON_LCD Block Diagram.....                       | 429 |
| Figure 5-2 HV Interface Vertical Timing .....                | 433 |
| Figure 5-3 HV Interface Horizontal Timing.....               | 434 |
| Figure 5-4 i8080 Interface Timing .....                      | 436 |
| Figure 5-5 LVDS Single Link JEDIA Mode Interface Timing..... | 437 |
| Figure 5-6 LVDS Single Link NS Mode Interface Timing .....   | 437 |
| Figure 5-7 LVDS Dual Link NS Mode Interface Timing .....     | 438 |
| Figure 5-8 CMAP Module .....                                 | 440 |
| Figure 5-9 FRM Module .....                                  | 440 |
| Figure 5-10 The Data Timing of MIPI DSI Video Mode.....      | 441 |
| Figure 5-11 HV Mode Initial Process .....                    | 441 |
| Figure 5-12 LVDS Mode Configuration Process .....            | 444 |
| Figure 5-13 i8080 Mode Initial Process.....                  | 447 |
| Figure 5-14 TVE Block Diagram .....                          | 496 |
| Figure 5-15 Auto Detection Function.....                     | 497 |
| Figure 5-16 DAC Calibration Function.....                    | 498 |
| Figure 5-17 Operating TVE Module.....                        | 499 |

## Tables

|                                                        |     |
|--------------------------------------------------------|-----|
| Table 5-1 LCD External Signals .....                   | 429 |
| Table 5-2 The Correspondence between LCD and RGB ..... | 430 |
| Table 5-3 The Correspondence between LCD and LVDS..... | 431 |
| Table 5-4 HV Panel Signals .....                       | 432 |
| Table 5-5 BT656 Panel Signals.....                     | 434 |
| Table 5-6 EAV and SAV Sequence .....                   | 435 |
| Table 5-7 CPU Panel Signals .....                      | 435 |
| Table 5-8 LVDS Panel Signals .....                     | 436 |
| Table 5-9 TCON_LCD Clock Sources .....                 | 438 |
| Table 5-10 RGB Gamma Correction Table .....            | 439 |
| Table 5-11 TVE External Signals .....                  | 496 |
| Table 5-12 TVE Clock Sources .....                     | 497 |

## 5 Video Output Interfaces

### 5.1 TCON LCD

#### 5.1.1 Overview

The Timing Controller\_LCD (TCON\_LCD) is a module that processes video signals received from system through a complicated arithmetic and then generates control signals and transmits them to the LCD panel driver IC.

The TCON\_LCD includes the following features:

- Supports RGB interface with DE/SYNC mode, up to 1920 x 1080@60fps
- Supports serial RGB/dummy RGB interface, up to 800 x 480@60fps
- Supports LVDS interface with dual link, up to 1920 x 1080@60fps
- Supports LVDS interface with single link, up to 1366 x 768@60fps
- Supports i8080 interface, up to 800 x 480@60fps
- Supports BT656 interface for NTSC and PAL
- Supports RGB666 and RGB565 with dither function
- Supports Gamma correction with R/G/B channel independence

### 5.1.2 Block Diagram

Figure 5-1 TCON\_LCD Block Diagram



### 5.1.3 Functional Description

#### 5.1.3.1 External Signals

The LCD external signals are used to connect to panel interface. The panel interface has various types.

Table 5-1 LCD External Signals

| Signal Name   | Description                                                | Type |
|---------------|------------------------------------------------------------|------|
| LCD0-D[23:0]  | LCD Data Output                                            | O    |
| LCD0-CLK      | LCD Clock<br>The pixel data are synchronized by this clock | O    |
| LCD0-VSYNC    | LCD Vertical Sync<br>It indicates one new frame            | O    |
| LCD0-HSYNC    | LCD Horizontal Sync<br>It indicates one new scan line      | O    |
| LCD0-DE       | LCD Data Output Enable                                     | O    |
| TCON-TRIG     | LCD Sync (TCON outputs to LCD for sync)                    | O    |
| LVDS0-CKP     | LVDS0 Positive Port of Clock                               | O    |
| LVDS0-CKN     | LVDS0 Negative Port of Clock                               | O    |
| LVDS0-V[3:0]P | LVDS0 Positive Port of Data Channel [3:0]                  | O    |

| Signal Name   | Description                               | Type |
|---------------|-------------------------------------------|------|
| LVDS0-V[3:0]N | LVDS0 Negative Port of Data Channel [3:0] | O    |
| LVDS1-CKP     | LVDS1 Positive Port of Clock              | O    |
| LVDS1-CKN     | LVDS1 Negative Port of Clock              | O    |
| LVDS1-V[3:0]P | LVDS1 Positive Port of Data Channel [3:0] | O    |
| LVDS1-V[3:0]N | LVDS1 Negative Port of Data Channel [3:0] | O    |

For parallel RGB, the data of LCD is high-aligned. The correspondence is as follows.

Table 5-2 The Correspondence between LCD and RGB

| LCD I/O  | Parallel RGB I/O |        |        |
|----------|------------------|--------|--------|
|          | RGB565           | RGB666 | RGB888 |
| LCD0-D23 | R4               | R5     | R7     |
| LCD0-D22 | R3               | R4     | R6     |
| LCD0-D21 | R2               | R3     | R5     |
| LCD0-D20 | R1               | R2     | R4     |
| LCD0-D19 | R0               | R1     | R3     |
| LCD0-D18 | -                | R0     | R2     |
| LCD0-D17 | -                | -      | R1     |
| LCD0-D16 | -                | -      | R0     |
| LCD0-D15 | G5               | G5     | G7     |
| LCD0-D14 | G4               | G4     | G6     |
| LCD0-D13 | G3               | G3     | G5     |
| LCD0-D12 | G2               | G2     | G4     |
| LCD0-D11 | G1               | G1     | G3     |
| LCD0-D10 | G0               | G0     | G2     |
| LCD0-D9  | -                | -      | G1     |
| LCD0-D8  | -                | -      | G0     |
| LCD0-D7  | B4               | B5     | B7     |
| LCD0-D6  | B3               | B4     | B6     |
| LCD0-D5  | B2               | B3     | B5     |
| LCD0-D4  | B1               | B2     | B4     |
| LCD0-D3  | B0               | B1     | B3     |
| LCD0-D2  | -                | B0     | B2     |
| LCD0-D1  | -                | -      | B1     |
| LCD0-D0  | -                | -      | B0     |

The multiplex relationship between LCD and LVDS is shown as follows.

**Table 5-3 The Correspondence between LCD and LVDS**

| LCD I/O  | LVDS I/O  |
|----------|-----------|
| LCD0-D2  | LVDS0-V0P |
| LCD0-D3  | LVDS0-V0N |
| LCD0-D4  | LVDS0-V1P |
| LCD0-D5  | LVDS0-V1N |
| LCD0-D6  | LVDS0-V2P |
| LCD0-D7  | LVDS0-V2N |
| LCD0-D10 | LVDS0-CKP |
| LCD0-D11 | LVDS0-CKN |
| LCD0-D12 | LVDS0-V3P |
| LCD0-D13 | LVDS0-V3N |
| LCD0-D14 | LVDS1-V0P |
| LCD0-D15 | LVDS1-V0N |
| LCD0-D18 | LVDS1-V1P |
| LCD0-D19 | LVDS1-V1N |
| LCD0-D20 | LVDS1-V2P |
| LCD0-D21 | LVDS1-V2N |
| LCD0-D22 | LVDS1-CKP |
| LCD0-D23 | LVDS1-CKN |
| LCD0-CLK | LVDS1-V3P |
| LCD0-DE  | LVDS1-V3N |

### 5.1.3.2 Control Signal and Data Port Mapping

|                 |                 | SYNC_RGB    |                 |                 |                 | CP-U<br>Cm<br>-d | CP-U<br>18-bit | CPU<br>16bit    |                 |                 |                 |                 |                 | CPU<br>8bit |                 |                |                 | CPU<br>9bit    |      | LVDS            |                |          |  |  |  |  |
|-----------------|-----------------|-------------|-----------------|-----------------|-----------------|------------------|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-------------|-----------------|----------------|-----------------|----------------|------|-----------------|----------------|----------|--|--|--|--|
| External<br>I/O | Internal<br>pin | Para<br>RGB | SerialRGB       |                 |                 | 656              | 25<br>6K       | 256K            |                 |                 |                 |                 |                 | 65<br>K     | 256K            |                | 65K             |                | 256K | Single<br>Link  |                | DualLink |  |  |  |  |
|                 |                 | RGB         | 1 <sup>st</sup> | 2 <sup>nd</sup> | 3 <sup>rd</sup> |                  |                | 1 <sup>st</sup> | 2 <sup>nd</sup> | 3 <sup>rd</sup> | 1 <sup>st</sup> | 2 <sup>nd</sup> | 1 <sup>st</sup> |             | 1 <sup>st</sup> | 2 <sup>n</sup> | 1 <sup>st</sup> | 2 <sup>n</sup> |      | 1 <sup>st</sup> | 2 <sup>n</sup> |          |  |  |  |  |
| LCD0_VSYN       | IO0             | VSYNC       |                 |                 | CS              |                  |                |                 |                 |                 | RD              |                 |                 |             |                 |                |                 |                |      |                 |                |          |  |  |  |  |
| LCD0_HSYN       | IO1             | HSYNC       |                 |                 |                 |                  |                |                 |                 |                 |                 |                 |                 |             |                 |                |                 |                |      |                 |                |          |  |  |  |  |

|          |     |      |     |     |     |    |     |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
|----------|-----|------|-----|-----|-----|----|-----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|------|------|
| LCD0_CLK | IO2 | DCLK |     |     |     |    | WR  |    |    |    |    |    |    |    |    |    |    |    | D3P2 | D3P2 |      |      |      |      |
| LCD0_DE  | IO3 | DE   |     |     |     |    | RS  |    |    |    |    |    |    |    |    |    |    |    | D3N2 | D3N2 |      |      |      |      |
| LCD0_D23 | D23 | R7   |     |     |     |    | D23 | R5 | R5 | B5 | G5 | R5 |    | R5 | B5 | R4 |    |    |      | CKN2 | CKN2 |      |      |      |
| LCD0_D22 | D22 | R6   |     |     |     |    | D22 | R4 | R4 | B4 | G4 | R4 |    | R4 | B4 | R3 |    |    |      | CKP2 | CKP2 |      |      |      |
| LCD0_D21 | D21 | R5   |     |     |     |    | D21 | R3 | R3 | B3 | G3 | R3 |    | R3 | B3 | R2 |    |    |      | D2N2 | D2N2 |      |      |      |
| LCD0_D20 | D20 | R4   |     |     |     |    | D20 | R2 | R2 | B2 | G2 | R2 |    | R2 | B2 | R1 |    |    |      | D2P2 | D2P2 |      |      |      |
| LCD0_D19 | D19 | R3   |     |     |     |    | D19 | R1 | R1 | B1 | G1 | R1 |    | R1 | B1 | R0 |    |    |      | D1N2 | D1N2 |      |      |      |
| LCD0_D18 | D18 | R2   |     |     |     |    | D18 | R0 | R0 | B0 | G0 | R0 |    | R0 | B0 | G5 |    |    |      | D1P2 | D1P2 |      |      |      |
| LCD0_D17 | D17 | R1   |     |     |     |    | D17 |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| LCD0_D16 | D16 | R0   |     |     |     |    | D16 |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| LCD0_D15 | D15 | G7   |     |     |     |    | D15 | G5 |    |    |    |    |    |    |    | G4 |    |    |      | D0N2 | D0N2 |      |      |      |
| LCD0_D14 | D14 | G6   |     |     |     |    | D14 | G4 |    |    |    |    |    |    |    | G3 |    |    |      | D0P2 | D0P2 |      |      |      |
| LCD0_D13 | D13 | G5   |     |     |     |    | D13 | G3 |    |    |    |    |    |    |    |    |    |    |      | D3N1 | D3N1 |      |      |      |
| LCD0_D12 | D12 | G4   | D71 | D72 | D73 | D7 | D12 | G2 | G5 | R5 | B5 | G5 | B5 | G5 |    | G2 | R5 | G5 | B5   | R4   | G2   | D3P1 |      |      |
| LCD0_D11 | D11 | G3   | D61 | D62 | D63 | D6 | D11 | G1 | G4 | R4 | B4 | G4 | B4 | G4 |    | G1 | R4 | G4 | B4   | R3   | G1   | CKN1 |      |      |
| LCD0_D10 | D10 | G2   | D51 | D52 | D53 | D5 | D10 | G0 | G3 | R3 | B3 | G3 | B3 | G3 |    | G0 | R3 | G3 | B3   | R2   | G0   | R3   | CKP1 |      |
| LCD0_D9  | D9  | G1   |     |     |     |    | D9  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| LCD0_D8  | D8  | G0   |     |     |     |    | D8  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| LCD0_D7  | D7  | B7   | D41 | D42 | D43 | D4 | D7  | B5 | G2 | R2 | B2 | G2 | B2 | G2 |    | B4 | R2 | G2 | B2   | R1   | B4   | R2   | B5   | D2N1 |
| LCD0_D6  | D6  | B6   | D31 | D32 | D33 | D3 | D6  | B4 | G1 | R1 | B1 | G1 | B1 | G1 |    | B3 | R1 | G1 | B1   | R0   | B3   | R1   | B4   | D2P1 |
| LCD0_D5  | D5  | B5   | D21 | D22 | D23 | D2 | D5  | B3 | G0 | R0 | B0 | G0 | B0 | G0 |    | B2 | R0 | G0 | B0   | G5   | B2   | R0   | B3   | D1N1 |
| LCD0_D4  | D4  | B4   | D11 | D12 | D13 | D1 | D4  | B2 |    |    |    |    |    |    |    | B1 |    |    |      | G4   | B1   | G5   | B2   | D1P1 |
| LCD0_D3  | D3  | B3   | D01 | D02 | D03 | D0 | D3  | B1 |    |    |    |    |    |    |    | B0 |    |    |      | G3   | B0   | G4   | B1   | D0N1 |
| LCD0_D2  | D2  | B2   |     |     |     |    | D2  | B0 |    |    |    |    |    |    |    |    |    |    |      | G3   | B0   | D0P1 |      | D0P1 |
| LCD0_D1  | D1  | B1   |     |     |     |    | D1  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |
| LCD0_D0  | D0  | B0   |     |     |     |    | D0  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |      |      |

### 5.1.3.3 HV interface (Sync+DE mode)

HV I/F is also known as Sync + DE mode, which is widely used in TFT LCD module for PMP/MP4 applications.

Its signals are define as:

**Table 5-4 HV Panel Signals**

| Signal Name | Description                                  | Type |
|-------------|----------------------------------------------|------|
| Vsync       | Vertical sync, indicates one new frame       | O    |
| Hsync       | Horizontal sync, indicates one new scan line | O    |
| DCLK        | Dot clock, pixel data are sync by this clock | O    |
| DE          | LCD data enable                              | O    |
| D[23..0]    | 24-bit RGB output from input FIFO for panel  | O    |

The timing diagram of HV interface is as follows.

**Figure 5-2 HV Interface Vertical Timing**

Figure 5-3 HV Interface Horizontal Timing



### 5.1.3.4 BT656 Interface

In HV serial YUV output mode, its timing is BT656 compatible. SAV adds right before active area every line; EAV adds right after active area every line.

Table 5-5 BT656 Panel Signals

| Signal Name | Description  | Type |
|-------------|--------------|------|
| DCLK        | Clock signal | O    |
| DATA[7:0]   | Data signal  | O    |

Its logic is:

F = "0" for Field 1 F = "1" for Field 2

V = "1" during vertical blanking

H = "0" at SAV H = "1" at EAV

P3-P0 = protection bits

$$P3 = V \oplus H$$

$$P2 = F \oplus H$$

$$P1 = F \oplus V$$

$$P0 = F \oplus V \oplus H$$

Where  $\oplus$  represents the exclusive-OR function.

The 4 byte SAV/EAV sequence is as follows.

**Table 5-6 EAV and SAV Sequence**

|             | 8-bit Data |    |    |    |    |    |    |    | 10-bit Data |    |
|-------------|------------|----|----|----|----|----|----|----|-------------|----|
|             | D9 (MSB)   | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1          | D0 |
| Preamble    | 1          | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1           | 1  |
|             | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  |
|             | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  |
| Status word | 1          | F  | V  | H  | P3 | P2 | P1 | P0 | 0           | 0  |

### 5.1.3.5 i8080 Interface

The i8080 I/F LCD panel is most common interface for small size, low resolution LCD panels. The CPU control signals are active low.

**Table 5-7 CPU Panel Signals**

| Signal Name | Description                                      | Type |
|-------------|--------------------------------------------------|------|
| CS          | Chip select, active low                          | O    |
| WR          | Write strobe, active low                         | O    |
| RD          | Read strobe, active low                          | O    |
| A1          | Address bit, controlled by "LCD_CPUI/F" BIT26/25 | O    |
| D[23..0]    | Digital RGB output signal                        | I/O  |

The following figure relationship between basic timing and CPU timing. WR is 180° delay of DCLK; CS is active when pixel data is valid; RD is always set to 1; A1 is set by "LCD\_CPUI/F".

Figure 5-4 i8080 Interface Timing



When CPU I/F is in IDLE state, it can generate WR/RD timing by setting “**Lcd\_CPUI/F**”. The CS strobe is one DCLK width, and the WR/RD strobe is half DCLK width.

### 5.1.3.6 LVDS Interface

Table 5-8 LVDS Panel Signals

| Signal Name | Description                         | Type |
|-------------|-------------------------------------|------|
| CKP         | The positive port of clock          | O    |
| CKN         | The negative port of clock          | O    |
| D0P         | The positive port of data channel 0 | O    |
| D0N         | The negative port of data channel 0 | O    |
| D1P         | The positive port of data channel 1 | O    |
| D1N         | The negative port of data channel 1 | O    |
| D2P         | The positive port of data channel 2 | O    |
| D2N         | The negative port of data channel 2 | O    |
| D3P         | The positive port of data channel 3 | O    |
| D3N         | The negative port of data channel 3 | O    |

The following figures show the timing of LVDS interface.

Figure 5-5 LVDS Single Link JEDIA Mode Interface Timing



Figure 5-6 LVDS Single Link NS Mode Interface Timing



Figure 5-7 LVDS Dual Link NS Mode Interface Timing



### 5.1.3.7 Clock Sources

The following table describes the clock sources of TCON\_LCD. Table 5-9 describes the clock sources of TCON\_LCD.

Table 5-9 TCON\_LCD Clock Sources

| Clock Sources  | Description                                                       |
|----------------|-------------------------------------------------------------------|
| PLL_VIDEO0(1X) | By default, PLL_VIDEO0(4X) is 1188 MHz, PLL_VIDEO0(1X) is 297 MHz |
| PLL_VIDEO0(4X) |                                                                   |

| Clock Sources    | Description                                                       |
|------------------|-------------------------------------------------------------------|
| PLL_VIDEO1(1X)   | By default, PLL_VIDEO1(4X) is 1188 MHz, PLL_VIDEO1(1X) is 297 MHz |
| PLL_VIDEO1(4X)   |                                                                   |
| PLL_PERI(2X)     | By default, PLL_PERI(2X) is 1.2 GHz                               |
| PLL_AUDIO1(DIV2) | By default, PLL_AUDIO1 is 3072 MHz, PLL_AUDIO1(DIV2) is 1536 MHz  |

### 5.1.3.8 RGB Gamma Correction

Function: This module correct the RGB input data of DE.

A 256\*8\*3 Byte register file is used to store the gamma table.

**Table 5-10 RGB Gamma Correction Table**

| Offset | Value                               |
|--------|-------------------------------------|
| 0x400  | { B0[7:0], G0[7:0], R0[7:0] }       |
| 0x404  | { B1[7:0], G1[7:0], R1[7:0] }       |
| .....  | .....                               |
| 0x7FC  | { B255[7:0], G255[7:0], R255[7:0] } |

### 5.1.3.9 CEU Module

This module enhances color data from DE .

$$R' = Rr * R + Rg * G + Rb * B + Rc$$

$$G' = Gr * R + Gg * G + Gb * B + Gc$$

$$B' = Br * R + Bg * G + Bb * B + Bc$$



#### NOTE

Rr, Rg, Rb, Gr, Gg, Gb, Br, Bg, Bb s13 (-16, 16)

Rc, Gc, Bc s19 (-16384, 16384)

R, G, B u8 [0-255]

R' has the range of [Rmin ,Rmax]

G' has the range of [Rmin ,Rmax]

B' has the range of [Rmin ,Rmax]

### 5.1.3.10 CMAP Module

Function: This module map color data from DE.

Every 4 input pixels are as a unit. A unit is divided into 12 bytes. Output byte can select one of those 12 bytes.

Note that even line and odd line can be different, and output can be 12 bytes (4 pixels) or reduce to 6 bytes (2 pixels).

**Figure 5-8 CMAP Module**



### 5.1.3.11 FRM Module

**Figure 5-9 FRM Module**



### 5.1.3.12 MIPI DS1

The requirements on MIPI DS1 mode are as follows.

- (1). When using MIPI DS1 as display interface, the data clk of TCON needs be started firstly.
- (2). When it is used with DS1 video mode, the setting of block space needs to meet the following relationship.

**Figure 5-10 The Data Timing of MIPI DS1 Video Mode**



### 5.1.4 Programming Guidelines

#### 5.1.4.1 HV Mode Configuration Process

**Figure 5-11 HV Mode Initial Process**



##### (1) Parallel RGB

###### Step 1 Select HV interface type

Configure LCD\_CTL\_REG[LCD\_IF] (reg0x40) to 0 to select HV (Sync+DE) mode, and configure LCD\_HV\_IF\_REG[HV\_MODE] (reg0x58) to 0 to select 24bit/1cycle parallel mode.

lcd\_dev[sel]->**lcd\_ctl.lcd\_if**=HV(Sync+DE);

lcd\_dev[sel]->**lcd\_ctl.src\_sel** = src; //src = DE/color/grayscale/...

lcd\_dev[sel]->**lcd\_hv\_ctl.hv\_mode** = 24bit/1cycle parallel mode;

## Step 2 Clock configuration



### NOTE

- In parallel RGB mode, the displayed pixel clock (pixel\_CLK) is required to be consistent with the DCLK, the pixel\_clk(pixel\_clk=Ht\*Vt\*frame rate) is decided by external LCD.
- When using phase adjustment function, the LCD\_IO\_POL\_REG.DCLK\_SEL (reg0x88) selects dclk0–2 of different phase, and LCD\_IO\_POL\_REG.IO2\_INV can achieve 180°phase delay.

Configure corresponding frequency by setting PLL\_VIDEO0/1 register, and configure TCON LCD0 Clock register.

Configure internal frequency division of TCON\_LCD. Based on clock source of TCON and DCLK clock ratio, configure LCD\_DCLK\_REG[LCD\_DCLK\_DIV]. If using phase adjustment function, LCD\_DCLK\_REG[LCD\_DCLK\_EN] needs be set, usually is 0xf. When the dclk1 and dclk2 in LCD\_DCLK\_REG[LCD\_DCLK\_EN] are used, the value of LCD\_DCLK\_REG[LCD\_DCLK\_DIV] needs no less than 6.

lcd\_dev[sel]->**lcd\_dclk.dclk\_en** = en;

lcd\_dev[sel]->**lcd\_dclk.dclk\_div** = div;

## Step 3 Set sequence parameters

The sequence parameters include x,ht,hbp,hspw,y,vt,vbp,vspw, and correspond to LCD\_BASE\_REG from reg0x48 to reg 0x54. Note that hbp includes hspw, and vbp includes vspw. And LCD\_BASE2\_REG.VT needs be set to the twice of the actual value.

lcd\_dev[sel]->**lcd\_basic0.x** = x-1;

lcd\_dev[sel]->**lcd\_basic0.y** = y-1;

lcd\_dev[sel]->**lcd\_basic1.ht** = ht-1;

lcd\_dev[sel]->**lcd\_basic1.hbp** = hbp-1;

lcd\_dev[sel]->**lcd\_basic2.vt** = vt\*2;

```
lcd_dev[sel]->lcd_basic2.vbp = vbp-1;  
lcd_dev[sel]->lcd_basic3.hspw = hspw-1;  
lcd_dev[sel]->lcd_basic3.vspw = vspw-1;
```

#### Step 4 Open IO output

Set the corresponding data IO enable and control signal IO enable of LCD\_IO\_TRI\_REG (reg0x8C) to 0 to start enable. Note that except the internal IO of TCON\_LCD, the external GPIO mapping needs to be set to LCD mode.

When some control signals require polarity reversal, it can realize by setting LCD\_IO\_POL\_REG.IO0~3\_INV (reg0x88).

#### Step 5 Set and open interrupt function

The LCD\_GINT0\_REG (reg0x4) controls interrupt mode and flag, and the LCD\_GINT1\_REG (reg0x8) sets the interrupt line position of Line interrupt mode.

##### V interrupt:

```
lcd_dev[sel]->lcd_gint0.vb_en = 1;
```

##### Line interrupt:

```
lcd_dev[sel]->lcd_gint1.lcd_line_int_num = line;
```

```
lcd_dev[sel]->lcd_gint0.line_en = 1;
```

#### Step 6 Open module enable

Enable LCD\_CTL\_REG.LCD\_EN (reg0x40) and LCD\_GCTL\_REG.LCD\_EN (reg0x00).

```
lcd_dev[sel]->lcd_ctl.lcd_en = 1;
```

```
lcd_dev[sel]->lcd_gctl.lcd_en = 1;
```

## (2) Serial RGB

The serial RGB mode is consistent with parallel RGB mode, the main difference is the definition of clock and the sequence of serial data. The difference is as follows.

#### Step 1 Select HV interface type

Set LCD\_CTL\_REG.LCD\_IF (reg0x40) to 0 to select HV(Sync+DE) mode; set LCD\_HV\_IF\_REG.HV\_MODE (reg0x58) to select 8bit/3cycle RGB serial mode (RGB888), 8bit/4cycle Dummy RGB mode (DRGB) or 8bit/4cycle RGB Dummy mode (RGBD).

```
lcd_dev[sel]->lcd_ctl.lcd_if = HV(Sync+DE);
```

```
lcd_dev[sel]->lcd_ctl.src_sel = src; //src = DE/color/grayscale/...
```

`lcd_dev[sel]->lcd_hv_ctl.hv_mode = Serial mode;`

### Step2、Step3: Set clock and sequence parameters

In serial RGB mode, DCLK is the transfer clock of each byte data. In the same resolution, pixel\_clk of serial RGB is three times of its clock in parallel RGB, and ht,hbp,hspw own the same conversion relation. When display is split into odd field and even field, LCD\_BASE2\_REG.VT needs not to be set to the twice of the actual value.

`lcd_dev[sel]->lcd_basic2.vt = vt;`

Set LCD\_HV\_IF\_REG.RGB888\_ODD\_ORDER/LCD\_HV\_IF\_REG.RGB888\_ODD\_EVEN to select RGB output sequence of the selected odd and even lines.

`lcd_dev[lcd_sel]->lcd_hv_ctl.srgb_seq_even = seq_even;`

`lcd_dev[lcd_sel]->lcd_hv_ctl.srgb_seq_odd = seq_odd;`

#### 5.1.4.2 LVDS Mode Configuration Process

Figure 5-12 LVDS Mode Configuration Process



The LVDS interface configuration process is similar to the parallel mode of HV mode, and adds the digital/analog configuration of LVDS interface.

**Step 1 Same as in step1 of parallel mode**

**Step 2 Clock configuration**



#### NOTE

In parallel mode, the displayed pixel clock (pixel\_CLK) is required to be consistent with the DCLK,  $\text{pixel\_clk} = \text{Ht} * \text{Vt} * \text{frame rate}$ .

- Configure LCD\_DCLK\_REG.LCD\_DCLK\_DIV (reg0x44) to 7 after DCLK is determined;
- Configure the PLL clock in CCU based on proportional relationship;

- Release the LVDS reset of TCON LCD BUS GATING RESET register;
- Other configurations remain unchanged.

```
lcd_dev[sel]->lcd_dclk.dclk_en = en;
```

```
lcd_dev[sel]->lcd_dclk.dclk_div = 7;
```

**Step 3 Same as in step3 of parallel mode****Step 4 Same as in step4 of parallel mode****Step 5 LVDS digital logic configuration**

Includes clock source select of module, LVDS link number, data mode and bit width configuration.

- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_CLK\_SEL (reg0x84) to set LCD CLK;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_LINK to set the required LVDS port number;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_MODE to set JEDIA and NS mode;
- Configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_BITWIDTH to select 24-bit or 18-bit width;
- Lastly configure LCD\_LVDS\_IF\_REG.LCD\_LVDS\_EN to start LVDS mode.

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_link = link_num-1;
```

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_mode = mode;
```

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_bitwidth = bitwidth;
```

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_clk_sel = clk_src;
```

```
lcd_dev[sel]->lcd_lvds_ctl.lvds_en = 1;
```

**NOTE**

If configuring the same source data output mode of dual link, except the reg0x84 register of TCON\_LCD0 needs be configured, the LCD\_LVDS\_IF\_REG.LCD\_LVDS\_CLK\_SEL, LCD\_LVDS\_IF\_REG.LCD\_LVDS\_LINK, LCD\_LVDS\_IF\_REG.LCD\_LVDS\_MODE, and LCD\_LVDS\_IF\_REG.LCD\_LVDS\_BITWIDTH of the reg0x244 register need be configured.

**Step 6 LVDS controller configuration**

**NOTE**

The TCON LCD0 PHY0 is controlled by COMBO\_PHY\_REG (reg0x1110, reg0x1114). The TCON LCD0 PHY1 is controlled by LCD\_LVDS0\_ANA\_REG (reg0x220).

**For PHY0:**

- Configure the reg\_verf1p6 (differential mode voltage) in reg0x1114 to 4;
- Configure the reg\_vref0p8 reg0x1114 (common mode voltage) in reg0x1114 to 3;
- Start en\_cp, en\_mipi, en\_lvds, and en\_combaldo in reg0x1110, in turn.

**For PHY1:**

The LVDS analog configuration process is to start clock and data channel, and set the common mode and differential mode voltage, and start module power.

- Configure LVDS\_HPREN\_DRVC and LVDS\_HPREN\_DRV. When LVDS signal is 18-bit, LVDS\_HPREN\_DRV=0x7; when LVDS signal is 24-bit, LVDS\_HPREN\_DRV=0xF;
- Configure LVDS0\_REG\_C (differential mode voltage) to 4;
- Configure LVDS0\_REG\_V (common mode voltage) to 3;
- Lastly, start module voltage, and enable EN\_LVDS and EN\_24M.

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_drvd = 0x7; //18-bit=0x7, 24-bit=0xf
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_drvc = 1;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.diff_level = diff;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.com_level = com;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.dual_src = link_src;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_24M = 1;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_lvds = 1;
```

```
lcd_dev[sel]->lcd_lvds_ana_ctl[lvds_num].bits.en_mb = 1;
```

**Step 7 Same as in step5 of parallel mode****Step 8 Same as in step6 of parallel mode**

### 5.1.4.3 i8080 Mode Configuration Process

Figure 5-13 i8080 Mode Initial Process



- Step 1** Select i8080 interface type.
- Step 2** The step is the same as HV mode, but pulse adjustment function is invalid.
- Step 3** The step is the same as HV mode. When using TRI mode, it is best to configure LCD timing parameters in HV mode , or a handful of functions such as CMAP will not be able to apply.
- Step 4** The step is the same as HV mode.
- Step 5** Select type and operating mode of i8080, the operating mode includes TRI mode and AUTO mode, and the two operating modes are different.

#### For TRI mode

- Step 6** Open TRI FIFO switch, and TRI mode function.
- Step 7** Set parameters of TRI mode, including block size, block space and block number.



#### NOTE

When output interface is parallel mode, then the setting value of block space parameter is not less than 20.

When output interface is 2 cycle serial mode, then the setting value of block space parameter is not less than 40.

When output interface is 3 cycle serial mode, then the setting value of block space parameter is not less than 60.

When output interface is 4 cycle serial mode, then the setting value of block space parameter is not less than 80.

- Step 8** Set the tri interrupt or counter interrupt. When using the two interrupts, mainly in the interrupt service function the tri start operation need be operated (the bit1 of LCD\_CPU\_IF\_REG is set to "1"). If using TE trigger interrupt, you select the external input pin as a trigger signal, the 24-bit for offset 0x8C register is set to "1", to open up input of pad.
- Step 9** Open the total switch of interrupt.
- Step 10** Open the total enable of interrupt.
- Step 11** Operate "tri start" operation (the bit1 of LCD\_CPU\_IF\_REG is set to "1").

**For Auto mode**

- Step 6** Set and open V interrupt or Line interrupt, the step is the same as HV mode.
- Step 7** Open module total enable.

**5.1.5 Register List**

| Module Name | Base Address |
|-------------|--------------|
| TCON_LCDO   | 0x05461000   |

| Register Name    | Offset        | Description                           |
|------------------|---------------|---------------------------------------|
| LCD_GCTL_REG     | 0x0000        | LCD Global Control Register           |
| LCD_GINT0_REG    | 0x0004        | LCD Global Interrupt Register0        |
| LCD_GINT1_REG    | 0x0008        | LCD Global Interrupt Register1        |
| LCD_FRM_CTL_REG  | 0x0010        | LCD FRM Control Register              |
| LCD_FRM_SEED_REG | 0x0014+N*0x04 | LCD FRM Seed Register (N=0,1,2,3,4,5) |
| LCD_FRM_TAB_REG  | 0x002C+N*0x04 | LCD FRM Table Register (N=0,1,2,3)    |
| LCD_3D_FIFO_REG  | 0x003C        | LCD 3D FIFO Register                  |
| LCD_CTL_REG      | 0x0040        | LCD Control Register                  |
| LCD_DCLK_REG     | 0x0044        | LCD Data Clock Register               |
| LCD_BASIC0_REG   | 0x0048        | LCD Basic Timing Register0            |
| LCD_BASIC1_REG   | 0x004C        | LCD Basic Timing Register1            |
| LCD_BASIC2_REG   | 0x0050        | LCD Basic Timing Register2            |
| LCD_BASIC3_REG   | 0x0054        | LCD Basic Timing Register3            |
| LCD_HV_IF_REG    | 0x0058        | LCD HV Panel Interface Register       |
| LCD_CPU_IF_REG   | 0x0060        | LCD CPU Panel Interface Register      |
| LCD_CPU_WR_REG   | 0x0064        | LCD CPU Panel Write Data Register     |
| LCD_CPU_RDO_REG  | 0x0068        | LCD CPU Panel Read Data Register0     |
| LCD_CPU_RD1_REG  | 0x006C        | LCD CPU Panel Read Data Register1     |

| Register Name          | Offset        | Description                             |
|------------------------|---------------|-----------------------------------------|
| LCD_LVDS_IF_REG        | 0x0084        | LCD LVDS Configure Register             |
| LCD_IO_POL_REG         | 0x0088        | LCD IO Polarity Register                |
| LCD_IO_TRI_REG         | 0x008C        | LCD IO Control Register                 |
| LCD_DEBUG_REG          | 0x00FC        | LCD Debug Register                      |
| LCD_CEU_CTL_REG        | 0x0100        | LCD CEU Control Register                |
| LCD_CEU_COEF_MUL_REG   | 0x0110+N*0x04 | LCD CEU Coefficient Register0 (N=0~10)  |
| LCD_CEU_COEF_ADD_REG   | 0x011C+N*0x10 | LCD CEU Coefficient Register1 (N=0,1,2) |
| LCD_CEU_COEF_RANG_REG  | 0x0140+N*0x04 | LCD CEU Coefficient Register2 (N=0,1,2) |
| LCD_CPU_TRI0_REG       | 0x0160        | LCD CPU Panel Trigger Register0         |
| LCD_CPU_TRI1_REG       | 0x0164        | LCD CPU Panel Trigger Register1         |
| LCD_CPU_TRI2_REG       | 0x0168        | LCD CPU Panel Trigger Register2         |
| LCD_CPU_TRI3_REG       | 0x016C        | LCD CPU Panel Trigger Register3         |
| LCD_CPU_TRI4_REG       | 0x0170        | LCD CPU Panel Trigger Register4         |
| LCD_CPU_TRI5_REG       | 0x0174        | LCD CPU Panel Trigger Register5         |
| LCD_CMAP_CTL_REG       | 0x0180        | LCD Color Map Control Register          |
| LCD_CMAP_ODD0_REG      | 0x0190        | LCD Color Map Odd Line Register0        |
| LCD_CMAP_ODD1_REG      | 0x0194        | LCD Color Map Odd Line Register1        |
| LCD_CMAP_EVEN0_REG     | 0x0198        | LCD Color Map Even Line Register0       |
| LCD_CMAP_EVEN1_REG     | 0x019C        | LCD Color Map Even Line Register1       |
| LCD_SAFE_PERIOD_REG    | 0x01F0        | LCD Safe Period Register                |
| LCD_LVDS0_ANA_REG      | 0x0220        | LCD LVDS Analog Register 0              |
| LCD_LVDS1_ANA_REG      | 0x0224        | LCD LVDS Analog Register 1              |
| LCD_SYNC_CTL_REG       | 0x0230        | LCD Sync Control Register               |
| LCD_SYNC_POS_REG       | 0x0234        | LCD Sync Position Register              |
| LCD_SLAVE_STOP_POS_REG | 0x0238        | LCD Slave Stop Position Register        |
| LCD_GAMMA_TABLE_REG    | 0x0400-0x07FF | LCD Gamma Table Register                |

### 5.1.6 Register Description

#### 5.1.6.1 0x0000 LCD Global Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: LCD_GCTL_REG                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/W        | 0x0         | LCD_EN<br>When it is disabled, the module will be reset to idle state.<br>0: Disable<br>1: Enable |
| 30             | R/W        | 0x0         | LCD_GAMMA_EN<br>Enable the Gamma correction function.<br>0: Disable<br>1: Enable                  |
| 29:0           | /          | /           | /                                                                                                 |

#### 5.1.6.2 0x0004 LCD Global Interrupt Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: LCD_GINT0_REG                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31             | R/W        | 0x0         | LCD_VB_INT_EN<br>Enable the Vb interrupt<br>0: Disable<br>1: Enable                       |
| 30             | /          | /           | /                                                                                         |
| 29             | R/W        | 0x0         | LCD_LINE_INT_EN<br>Enable the line interrupt<br>0: Disable<br>1: Enable                   |
| 28             | /          | /           | /                                                                                         |
| 27             | R/W        | 0x0         | LCD_TRI_FINISH_INT_EN<br>Enable the trigger finish interrupt<br>0: Disable<br>1: Enable   |
| 26             | R/W        | 0x0         | LCD_TRI_COUNTER_INT_EN<br>Enable the trigger counter interrupt<br>0: Disable<br>1: Enable |
| 25:16          | /          | /           | /                                                                                         |

| Offset: 0x0004 |            |             | Register Name: LCD_GINT0_REG                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                   |
| 15             | R/WOC      | 0x0         | LCD_VB_INT_FLAG<br>Asserted during vertical no-display period every frame<br>Write 0 to clear it.                                             |
| 14             | /          | /           | /                                                                                                                                             |
| 13             | R/WOC      | 0x0         | LCD_LINE_INT_FLAG<br>Trigger when SY0 match the current LCD scan line<br>Write 0 to clear it.                                                 |
| 12             | /          | /           | /                                                                                                                                             |
| 11             | R/WOC      | 0x0         | LCD_TRI_FINISH_INT_FLAG<br>Trigger when cpu trigger mode finished<br>Write 0 to clear it.                                                     |
| 10             | R/WOC      | 0x0         | LCD_TRI_COUNTER_INT_FLAG<br>Trigger when tri counter reaches this value<br>Write 0 to clear it.                                               |
| 9              | R/WOC      | 0x0         | LCD_TRI_UNDERFLOW_FLAG<br>Only used in dsi video mode, tri when sync by dsi but not finish<br>Write 0 to clear it.                            |
| 8:3            | /          | /           | /                                                                                                                                             |
| 2              | R/WOC      | 0x0         | FSYNC_INT_INV<br>Enable the fsync interrupt to set signal inverse polarity.<br>When FSYNC is positive, this bit must be 1.<br>And vice versa. |
| 1              | R/WOC      | 0x0         | DE_INT_FLAG<br>Asserted at the first valid line in every frame<br>Write 0 to clear it.                                                        |
| 0              | R/WOC      | 0x0         | FSYNC_INT_FLAG<br>Asserted at the fsync signal in every frame<br>Write 0 to clear it.                                                         |

### 5.1.6.3 0x0008 LCD Global Interrupt Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: LCD_GINT1_REG                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:28          | /          | /           | /                                                                                                                                                                                                  |
| 27:16          | R/W        | 0x0         | LCD_LINE_INT_NUM<br>Scan line for LCD line trigger (including inactive lines).<br>Setting it for the specified line for trigger0.<br><b>Note: SY0 is writable only when LINE_TRG0 is disabled.</b> |
| 15:0           | /          | /           | /                                                                                                                                                                                                  |

### 5.1.6.4 0x0010 LCD FRM Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: LCD_FRM_CTL_REG                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31             | R/W        | 0x0         | LCD_FRM_EN<br>Enable the dither function<br>0: Disable<br>1: Enable                                                                                         |
| 30:7           | /          | /           | /                                                                                                                                                           |
| 6              | R/W        | 0x0         | LCD_FRM_MODE_R<br>The R component output bits in dither function<br>0: 6-bit frm output<br>1: 5-bit frm output                                              |
| 5              | R/W        | 0x0         | LCD_FRM_MODE_G<br>The G component output bits in dither function<br>0: 6-bit frm output<br>1: 5-bit frm output                                              |
| 4              | R/W        | 0x0         | LCD_Frm_MODE_B<br>The B component output bits in dither function<br>0: 6-bit frm output<br>1: 5-bit frm output                                              |
| 3:2            | /          | /           | /                                                                                                                                                           |
| 1:0            | R/W        | 0x0         | LCD_FRM_TEST<br>Set the test mode of dither function<br>00: FRM<br>01: Half 5-/6-bit, half FRM<br>10: Half 8-bit, half FRM<br>11: Half 8-bit, half 5-/6-bit |

### 5.1.6.5 0x0014+N\*0x04 (N=0~5) LCD FRM Seed Register (Default Value: 0x0000\_0000)

| Offset: 0x0014+N*0x04 (N=0~5) |            |             | Register Name: |
|-------------------------------|------------|-------------|----------------|
| Bit                           | Read/Write | Default/Hex | Description    |
| 31:25                         | /          | /           | /              |

| Offset: 0x0014+N*0x04 (N=0~5) |            |             | Register Name:                                                                                                                                                                                                                      |
|-------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                         |
| 24:0                          | R/W        | 0x0         | <p>SEED_VALUE<br/>Set the seed used in dither function<br/>N=0: Pixel_Seed_R<br/>N=1: Pixel_Seed_G<br/>N=2: Pixel_Seed_B<br/>N=3: Line_Seed_R<br/>N=4: Line_Seed_G<br/>N=5: Line_Seed_B<br/><b>Note: Avoid setting it to 0.</b></p> |

### 5.1.6.6 0x002C+N\*0x04 (N=0~3) LCD FRM Table Register (Default Value: 0x0000\_0000)

| Offset: 0x002C+N*0x04 (N=0~3) |            |             | Register Name: LCD_FRM_TAB_REG                                                                                                                                                              |
|-------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:0                          | R/W        | 0x0         | <p>FRM_TABLE_VALUE<br/>Set the data used in dither function<br/>Usually set as follows:<br/>Table0 = 0x01010000<br/>Table1 = 0x15151111<br/>Table2 = 0x57575555<br/>Table3 = 0x7f7f7777</p> |

### 5.1.6.7 0x003C LCD 3D FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: LCD_3D_FIFO_REG                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31             | R/W        | 0x0         | <p>3D_FIFO_BIST_EN<br/>Enable the 3D fifo bist test function<br/>0: Disable<br/>1: Enable</p>                                                |
| 30:14          | /          | /           | /                                                                                                                                            |
| 13:4           | R/W        | 0x0         | <p>3D_FIFO_HALF_LINE_SIZE<br/>The number of data in half line=3D_FIFO_HALF_LINE_SIZE+1,<br/>only valid when 3D_FIFO_SETTING is set as 2.</p> |
| 3:2            | /          | /           | /                                                                                                                                            |

| Offset: 0x003C |            |             | Register Name: LCD_3D_FIFO_REG                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 1:0            | R/W        | 0x0         | <p>3D_FIFO_SETTING<br/>Set the work mode of 3D FIFO</p> <p>00: Bypass<br/>01: Used as normal FIFO<br/>10: Used as 3D interlace FIFO<br/>11: Reserved</p> |

### 5.1.6.8 0x0040 LCD Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: LCD_CTL_REG                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31             | R/W        | 0x0         | <p>LCD_EN<br/>It executes at the beginning of the first blank line of LCD timing.</p> <p>0: Disable<br/>1: Enable</p>                        |
| 30:26          | /          | /           | /                                                                                                                                            |
| 25:24          | R/W        | 0x0         | <p>LCD_IF<br/>Set the interface type of LCD controller.</p> <p>00: HV(Sync+DE)<br/>01: 8080 I/F<br/>1x: Reserved</p>                         |
| 23             | R/W        | 0x0         | <p>LCD_RB_SWAP<br/>Enable the function to swap red data and blue data in fifo1.</p> <p>0: Default<br/>1: Swap RED and BLUE data at FIFO1</p> |
| 22             | /          | /           | /                                                                                                                                            |
| 21             | R/W        | 0x0         | <p>LCD_FIFO1_RST<br/>Writing 1 and then 0 to this bit will reset FIFO 1</p> <p>Note: 1 holding time must more than 1 DCLK</p>                |
| 20             | R/W        | 0x0         | <p>LCD_INTERLACE_EN<br/>This flag is valid only when LCD_EN == 1</p> <p>0: Disable<br/>1: Enable</p>                                         |
| 19:9           | /          | /           | /                                                                                                                                            |
| 8:4            | R/W        | 0x0         | <p>LCD_START_DLY<br/>The unit of delay is T_line.</p> <p>Note: Valid only when LCD_EN == 1</p>                                               |
| 3              | /          | /           | /                                                                                                                                            |

| Offset: 0x0040 |            |             | Register Name: LCD_CTL_REG                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 2:0            | R/W        | 0x0         | <p>LCD_SRC_SEL<br/>LCD Source Select<br/>000: DE<br/>001: Color Check<br/>010: Grayscale Check<br/>011: Black by White Check<br/>100: Test Data all 0<br/>101: Test Data all 1<br/>110: Reversed<br/>111: Gridding Check</p> |

#### 5.1.6.9 0x0044 LCD Data Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: LCD_DCLK_REG                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:28          | R/W        | 0x0         | <p>LCD_DCLK_EN<br/>LCD clock enable<br/>0000: dclk_en = 0; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 0;<br/>0001: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 0;<br/>0010: dclk_en = 1; dclk1_en = 0; dclk2_en = 0; dclkm2_en = 1;<br/>0011: dclk_en = 1; dclk1_en = 1; dclk2_en = 0; dclkm2_en = 0;<br/>0101: dclk_en = 1; dclk1_en = 0; dclk2_en = 1; dclkm2_en = 0;<br/>1111: dclk_en = 1; dclk1_en = 1; dclk2_en = 1; dclkm2_en = 1;<br/>Others: Reversed</p> |
| 27:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6:0            | R/W        | 0x0         | <p>LCD_DCLK_DIV<br/>Tdclk = Tsclk/DCLKDIV<br/>Note:<br/>1.If dclk1&amp;dclk2 are used, DCLKDIV &gt;=6<br/>2.If only dclk is used, DCLKDIV &gt;=1</p>                                                                                                                                                                                                                                                                                                                     |

#### 5.1.6.10 0x0048 LCD Basic Timing Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: LCD_BASIC0_REG |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:28          | /          | /           | /                             |
| 27:16          | R/W        | 0x0         | WIDTH_X<br>Panel width is X+1 |

| Offset: 0x0048 |            |             | Register Name: LCD_BASIC0_REG   |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 15:12          | /          | /           | /                               |
| 11:0           | R/W        | 0x0         | HEIGHT_Y<br>Panel height is Y+1 |

#### 5.1.6.11 0x004C LCD Basic Timing Register1 (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: LCD_BASIC1_REG                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                |
| 28:16          | R/W        | 0x0         | HT<br>Thcycle = (HT+1) * Tdclk<br>Computation:<br>1) parallel: HT = X + BLANK<br>Limitation:<br>1) parallel: HT >= (HBP +1) + (X+1) +2<br>2) serial 1: HT >= (HBP +1) + (X+1) *3+2<br>3) serial 2: HT >= (HBP +1) + (X+1) *3/2+2 |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                |
| 11:0           | R/W        | 0x0         | HBP<br>Horizontal back porch (in dclk)<br>Thbp = (HBP +1) * Tdclk                                                                                                                                                                |

#### 5.1.6.12 0x0050 LCD Basic Timing Register2 (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: LCD_BASIC2_REG                              |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:29          | /          | /           | /                                                          |
| 28:16          | R/W        | 0x0         | VT<br>TVT = (VT)/2 * Thsync<br>VT/2 >= (VBP+1 ) + (Y+1) +2 |
| 15:12          | /          | /           | /                                                          |
| 11:0           | R/W        | 0x0         | VBP<br>Tvbp = (VBP +1) * Thsync                            |

### 5.1.6.13 0x0054 LCD Basic Timing Register3 (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: LCD_BASIC3_REG                        |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:26          | /          | /           | /                                                    |
| 25:16          | R/W        | 0x0         | HSPW<br>Thspw = (HSPW+1) * Tdclk<br>HT > (HSPW+1)    |
| 15:10          | /          | /           | /                                                    |
| 9:0            | R/W        | 0x0         | VSPW<br>Tvspw = (VSPW+1) * Thsync<br>VT/2 > (VSPW+1) |

### 5.1.6.14 0x0058 LCD HV Panel Interface Register (Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: LCD_HV_IF_REG                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
| 31:28          | R/W        | 0x0         | HV_MODE<br>Set the HV mode of LCD controller<br>0000: 24-bit/1-cycle parallel mode<br>1000: 8-bit/3-cycle RGB serial mode (RGB888)<br>1010: 8-bit/4-cycle Dummy RGB (DRGB)<br>1011: 8-bit/4-cycle RGB Dummy (RGBD)<br>1100: 8-bit/2-cycle YUV serial mode (CCIR656) |
| 27:26          | R/W        | 0x0         | RGB888_ODD_ORDER<br>Serial RGB888 mode Output sequence at odd lines of the panel<br>(line 1, 3, 5, 7...).<br>00: R→G→B<br>01: B→R→G<br>10: G→B→R<br>11: R→G→B                                                                                                       |
| 25:24          | R/W        | 0x0         | RGB888_EVEN_ORDER<br>Serial RGB888 mode Output sequence at even lines of the panel<br>(line 2, 4, 6, 8...).<br>00: R→G→B<br>01: B→R→G<br>10: G→B→R<br>11: R→G→B                                                                                                     |

| Offset: 0x0058 |            |             | Register Name: LCD_HV_IF_REG                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 23:22          | R/W        | 0x0         | <p>YUV_SM<br/>Serial YUV mode Output sequence 2-pixel-pair of every scan line.</p> <p>00: YUYV<br/>01: VYU<br/>10: UYVY<br/>11: VYUY</p>                                                       |
| 21:20          | R/W        | 0x0         | <p>YUV_EAV_SAV_F_LINE_DLY<br/>Set the delay line mode.</p> <p>00: F toggle right after active video line<br/>01: delay 2 line (CCIR PAL)<br/>10: delay 3 line (CCIR NTSC)<br/>11: reserved</p> |
| 19             | R/W        | 0x0         | <p>CCIR_CSC_DIS<br/>LCD convert source from RGB to YUV.</p> <p>0: Enable<br/>1: Disable<br/>Only valid when HV mode is "1100".</p>                                                             |
| 18:0           | /          | /           | /                                                                                                                                                                                              |

### 5.1.6.15 0x0060 LCD CPU Panel Interface Register (Default Value: 0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: LCD_CPU_IF_REG                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | <p>CPU_MODE<br/>Set the cpu interface work mode</p> <p>0000: 18-bit/256K mode<br/>0010: 16-bit mode0<br/>0100: 16-bit mode1<br/>0110: 16-bit mode2<br/>1000: 16-bit mode3<br/>1010: 9-bit mode<br/>1100: 8-bit 256K mode<br/>1110: 8-bit 65K mode<br/>xxx1: 24-bit for DSI</p> |
| 27             | /          | /           | /                                                                                                                                                                                                                                                                              |
| 26             | R/W        | 0x0         | <p>DA<br/>Pin A1 value in 8080 mode auto/flash states</p>                                                                                                                                                                                                                      |
| 25             | R/W        | 0x0         | <p>CA<br/>Pin A1 value in 8080 mode WR/RD execute</p>                                                                                                                                                                                                                          |

| Offset: 0x0060 |            |             | Register Name: LCD_CPU_IF_REG                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 24             | /          | /           | /                                                                                                                                                                                                           |
| 23             | R          | 0x0         | WR_FLAG<br>The status of write operation.<br>0: Write operation is finishing<br>1: Write operation is pending                                                                                               |
| 22             | R          | 0x0         | RD_FLAG<br>The status of read operation.<br>0: Read operation is finishing<br>1: Read operation is pending                                                                                                  |
| 21:18          | /          | /           | /                                                                                                                                                                                                           |
| 17             | R/W        | 0x0         | AUTO<br>Auto transfer mode<br>If it is 1, all the valid data during this frame are written to panel.<br><b>Note: This bit is sampled by Vsync.</b>                                                          |
| 16             | R/W        | 0x0         | FLUSH<br>Direct transfer mode<br>If it is enabled, FIFO1 is regardless of the HV timing, the pixels data keep being transferred unless the input FIFO was empty.<br>Data output rate is controlled by DCLK. |
| 15:4           | /          | /           | /                                                                                                                                                                                                           |
| 3              | R/W        | 0x0         | TRI_FIFO_BIST_EN<br>Entry address is 0xFF8<br>0: Disable<br>1: Enable                                                                                                                                       |
| 2              | R/W        | 0x0         | TRI_FIFO_EN<br>Enable the trigger FIFO<br>0: Disable<br>1: Enable                                                                                                                                           |
| 1              | R/W1S      | 0x0         | TRI_START<br>Software must make sure that write '1' only when this flag is '0'.<br>Writing '1' starts a frame flush and writing '0' has no effect.<br>This flag indicates the frame flush is running.       |
| 0              | R/W        | 0x0         | TRI_EN<br>Enable trigger mode<br>0: Trigger mode disable<br>1: Trigger mode enable                                                                                                                          |

**5.1.6.16 0x0064 LCD CPU Panel Write Data Register (Default Value: 0x0000\_0000)**

| Offset: 0x0064 |            |             | Register Name: LCD_CPU_WR_REG                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:24          | /          | /           | /                                                                        |
| 23:0           | W          | 0x0         | DATA_WR<br>Data write on 8080 bus, launch a write operation on 8080 bus. |

**5.1.6.17 0x0068 LCD CPU Panel Read Data Register0 (Default Value: 0x0000\_0000)**

| Offset: 0x0068 |            |             | Register Name: LCD_CPU_RD0_REG                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:24          | /          | /           | /                                                                           |
| 23:0           | R          | 0x0         | DATA_RD0<br>Data read on 8080 bus, launch a new read operation on 8080 bus. |

**5.1.6.18 0x006C LCD CPU Panel Read Data Register1 (Default Value: 0x0000\_0000)**

| Offset: 0x006C |            |             | Register Name: LCD_CPU_RD1_REG                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:24          | /          | /           | /                                                                            |
| 23:0           | R          | 0x0         | DATA_RD1<br>Data read on 8080 bus, without a new read operation on 8080 bus. |

**5.1.6.19 0x0084 LCD LVDS Interface Register (Default Value: 0x0000\_0000)**

| Offset: 0x0084 |            |             | Register Name: LCD_LVDS_IF_REG                                   |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31             | R/W        | 0           | LCD_LVDS_EN<br>Enable LVDS interface.<br>0: Disable<br>1: Enable |

| Offset: 0x0084 |            |             | Register Name: LCD_LVDS_IF_REG                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                          |
| 30             | R/W        | 0           | LCD_LVDS_LINK<br>Select work in single link mode or dual link mode<br>0: Single link<br>1: Dual link                                 |
| 29             | R/W        | 0           | LCD_LVDS EVEN ODD DIR<br>Set the order of even field and odd field<br>0: normal<br>1: reverse                                        |
| 28             | R/W        | 0           | LCD_LVDS_DIR<br>Set the LVDS direction<br>0: Normal<br>1: Reverse                                                                    |
| 27             | R/W        | 0           | LCD_LVDS_MODE<br>Set the LVDS data mode<br>0: NS mode<br>1: JEIDA mode                                                               |
| 26             | R/W        | 0           | LCD_LVDS_BITWIDTH<br>Set the bit width of data<br>0: 24-bit<br>1: 18-bit                                                             |
| 25             | R/W        | 0           | LCD_LVDS_DEBUG_EN<br>Enable LVDS debug function<br>0: Disable<br>1: Enable                                                           |
| 24             | R/W        | 0           | LCD_LVDS_DEBUG_MODE<br>Set the output signal in debug mode<br>0: Mode0—Random data<br>1: Mode1—Output CLK period=7/2 LVDS CLK period |
| 23             | R/W        | 0           | LCD_LVDS_CORRECT_MODE<br>Set the LVDS correct mode<br>0: Mode0<br>1: Mode1                                                           |
| 22:21          | /          | /           | /                                                                                                                                    |
| 20             | R/W        | 0           | LCD_LVDS_CLK_SEL<br>Select the clock source of LVDS<br>0: Reserved<br>1: LCD CLK                                                     |
| 19:5           | /          | /           | /                                                                                                                                    |
| 4              | R/W        | 0           | LCD_LVDS_CLK_POL<br>Set the clock polarity of LVDS<br>0: Reverse<br>1: Normal                                                        |

| Offset: 0x0084 |            |             | Register Name: LCD_LVDS_IF_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 3:0            | R/W        | 0           | LCD_LVDS_DATA_POL<br>Set the data polarity of LVDS<br>0: Reverse<br>1: Normal |

#### 5.1.6.20 0x0088 LCD IO Polarity Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: LCD_IO_POL_REG                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                              |
| 31             | R/W        | 0x0         | IO_OUTPUT_SEL<br>When it is set as '1', the d[23:0], io0, io1, io3 are sync to dclk.<br>0: Normal output<br>1: Register output                                                                                                                           |
| 30:28          | R/W        | 0x0         | DCLK_SEL<br>Set the phase offset of clock and data in hv mode.<br>000: Used DCLK0 (normal phase offset)<br>001: Used DCLK1 (1/3 phase offset)<br>010: Used DCLK2 (2/3 phase offset)<br>100: DCLK0/2 phase 0<br>101: DCLK0/2 phase 90<br>Others: Reserved |
| 27             | R/W        | 0x0         | IO3_INV<br>Enable invert function of IO3<br>0: Not invert<br>1: Invert                                                                                                                                                                                   |
| 26             | R/W        | 0x0         | IO2_INV<br>Enable invert function of IO2<br>0: Not invert<br>1: Invert                                                                                                                                                                                   |
| 25             | R/W        | 0x0         | IO1_INV<br>Enable invert function of IO1<br>0: Not invert<br>1: Invert                                                                                                                                                                                   |
| 24             | R/W        | 0x0         | IO0_INV<br>Enable invert function of IO0<br>0: Not invert<br>1: Invert                                                                                                                                                                                   |

| Offset: 0x0088 |            |             | Register Name: LCD_IO_POL_REG                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 23:0           | R/W        | 0x0         | <p>Data_INV</p> <p>LCD output port D[23:0] polarity control, with independent bit control.</p> <p>0: Normal polarity</p> <p>1: Invert the specify output</p> |

#### 5.1.6.21 0x008C LCD IO Control Register (Default Value: 0xFFFF\_FFFF)

| Offset: 0x008C |            |             | Register Name: LCD_IO_TRI_REG                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:29          | /          | /           | /                                                                                                                                        |
| 28             | R/W        | 0x0         | <p>RGB_ENDIAN</p> <p>Set the endian of data bits</p> <p>0: Normal</p> <p>1: Bits_invert</p>                                              |
| 27             | R/W        | 0x1         | <p>IO3_OUTPUT_TRI_EN</p> <p>Enable the output of IO3</p> <p>1: Disable</p> <p>0: Enable</p>                                              |
| 26             | R/W        | 0x1         | <p>IO2_OUTPUT_TRI_EN</p> <p>Enable the output of IO2</p> <p>1: Disable</p> <p>0: Enable</p>                                              |
| 25             | R/W        | 0x1         | <p>IO1_OUTPUT_TRI_EN</p> <p>Enable the output of IO1</p> <p>1: Disable</p> <p>0: Enable</p>                                              |
| 24             | R/W        | 0x1         | <p>IO0_OUTPUT_TRI_EN</p> <p>Enable the output of IO0</p> <p>1: Disable</p> <p>0: Enable</p>                                              |
| 23:0           | R/W        | 0xFFFFFFF   | <p>DATA_OUTPUT_TRI_EN</p> <p>LCD output port D[23:0] output enable, with independent bit control.</p> <p>1: Disable</p> <p>0: Enable</p> |

### 5.1.6.22 0x00FC LCD Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x00FC |            |             | Register Name: LCD_DEBUG_REG                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31             | R          | 0x0         | LCD_FIFO_UNDERFLOW<br>The flag shows whether the fifos in underflow status<br>0: Not underflow<br>1: Underflow |
| 30             | /          | /           | /                                                                                                              |
| 29             | R          | 0x0         | LCD_FIELD_POL<br>The flag indicates the current field polarity<br>0: Second field<br>1: First field            |
| 28             | /          | /           | /                                                                                                              |
| 27:16          | R          | 0x0         | LCD_CURRENT_LINE<br>The current scan line                                                                      |
| 15:0           | /          | /           | /                                                                                                              |

### 5.1.6.23 0x0100 LCD CEU Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: LCD_CEU_CTL_REG                          |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31             | R/W        | 0x0         | CEU_EN<br>Enable CEU function<br>0: Bypass<br>1: Enable |
| 30             | R/W        | 0x0         | BT656_F_MASK<br>BT656 F Mask<br>0: Disable<br>1: Enable |
| 29             | R/W        | 0x0         | BT656_F_MASK_VALUE<br>BT656 F Mask Value                |
| 28:0           | /          | /           | /                                                       |

### 5.1.6.24 0x0110+N\*0x04 (N=0~10) LCD CEU Coefficient Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0110+N*0x04 (N=0~10) |            |             | Register Name: LCD_CEU_COEF_MUL_REG |
|--------------------------------|------------|-------------|-------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                         |
| 31:13                          | /          | /           | /                                   |

| Offset: 0x0110+N*0x04 (N=0~10) |            |             | Register Name: LCD_CEU_COEF_MUL_REG                                                                                                                                                |
|--------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 12:0                           | R/W        | 0x0         | <p>CEU_COEF_MUL_VALUE<br/>Signed 13-bit value, range of (-16,16).<br/>N=0: Rr<br/>N=1: Rg<br/>N=2: Rb<br/>N=4: Gr<br/>N=5: Gg<br/>N=6: Gb<br/>N=8: Br<br/>N=9: Bg<br/>N=10: Bb</p> |

#### 5.1.6.25 0x011C+N\*0x10 (N=0~2) LCD CEU Coefficient Register1 (Default Value: 0x0000\_0000)

| Offset: 0x011C+N*0x10 (N=0~2) |            |             | Register Name: LCD_CEU_COEF_ADD_REG                                                                              |
|-------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                      |
| 31:19                         | /          | /           | /                                                                                                                |
| 18:0                          | R/W        | 0x0         | <p>CEU_COEF_ADD_VALUE<br/>Signed 19-bit value, range of (-16384, 16384).<br/>N=0: Rc<br/>N=1: Gc<br/>N=2: Bc</p> |

#### 5.1.6.26 0x0140+N\*0x04 (N=0~2) LCD CEU Coefficient Register2 (Default Value: 0x0000\_0000)

| Offset: 0x0140+N*0x04 (N=0~2) |            |             | Register Name: LCD_CEU_COEF_RANG_REG                                   |
|-------------------------------|------------|-------------|------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                            |
| 31:24                         | /          | /           | /                                                                      |
| 23:16                         | R/W        | 0x0         | <p>CEU_COEF_RANGE_MIN<br/>Unsigned 8-bit value, range of [0, 255].</p> |
| 15:8                          | /          | /           | /                                                                      |
| 7:0                           | R/W        | 0x0         | <p>CEU_COEF_RANGE_MAX<br/>Unsigned 8-bit value, range of [0, 255].</p> |

### 5.1.6.27 0x0160 LCD CPU Panel Trigger Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: LCD_CPU_TRI0_REG                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
| 31:28          | /          | /           | /                                                                             |
| 27:16          | R/W        | 0x0         | BLOCK_SPACE<br>The spaces between data blocks.<br>It should be set >20*pixel. |
| 15:12          | /          | /           | /                                                                             |
| 11:0           | R/W        | 0x0         | BLOCK_SIZE<br>The size of data block. It is usually set as X.                 |

### 5.1.6.28 0x0164 LCD CPU Panel Trigger Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0164 |            |             | Register Name: LCD_CPU_TRI1_REG                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:16          | R          | 0x0         | BLOCK_CURRENT_NUM<br>Shows the current data block transmitting to panel. |
| 15:0           | R/W        | 0x0         | BLOCK_NUM<br>The number of data blocks. It is usually set as Y.          |

### 5.1.6.29 0x0168 LCD CPU Panel Trigger Register2 (Default Value: 0x0020\_0000)

| Offset: 0x0168 |            |             | Register Name: LCD_CPU_TRI2_REG                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:16          | R/W        | 0x20        | START_DLY<br>$T_{dly} = (\text{Start\_Delay} + 1) * \text{be\_clk} * 8.$                      |
| 15             | R/W        | 0x0         | TRANS_START_MODE<br>Select the FIFOs used in CPU mode.<br>0: ECC_FIFO+TRI_FIFO<br>1: TRI_FIFO |
| 14:13          | R/W        | 0x0         | SYNC_MODE<br>Set the sync mode in CPU interface.<br>0x: Auto<br>10: 0<br>11: 1                |
| 12:0           | R/W        | 0x0         | TRANS_START_SET<br>Usual set as the length of a line.                                         |

### 5.1.6.30 0x016C LCD CPU Panel Trigger Register3 (Default Value: 0x0000\_0000)

| Offset: 0x016C |            |             | Register Name: LCD_CPU_TRI3_REG                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                           |
| 29:28          | R/W        | 0x0         | TRI_INT_MODE<br>When set as 01, the Tri_Counter_Int occurs in cycle of (Count_N+1)×(Count_M+1)×4 dclk.<br>When set as 10 or 11, the io0 is map as TE input.<br>00: Disable<br>01: Counter mode<br>10: Te rising mode<br>11: Te falling mode |
| 27:24          | /          | /           | /                                                                                                                                                                                                                                           |
| 23:8           | R/W        | 0x0         | COUNTER_N<br>The value of counter factor                                                                                                                                                                                                    |
| 7:0            | R/W        | 0x0         | COUNTER_M<br>The value of counter factor                                                                                                                                                                                                    |

### 5.1.6.31 0x0170 LCD CPU Panel Trigger Register4 (Default Value: 0x0000\_0000)

| Offset: 0x0170 |            |             | Register Name: LCD_CPU_TRI4_REG                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:29          | /          | /           | /                                                                                         |
| 28             | R/W        | 0x0         | PLUG_MODE_EN<br>Enable the plug mode used in dsi command mode.<br>0: Disable<br>1: Enable |
| 27:25          | /          | /           | /                                                                                         |
| 24             | R/W        | 0x0         | A1_First_Valid<br>Valid in first Block.                                                   |
| 23:0           | R/W        | 0x0         | D23_TO_D0_First_Valid<br>Valid in first Block.                                            |

### 5.1.6.32 0x0174 LCD CPU Panel Trigger Register5 (Default Value: 0x0000\_0000)

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

| Offset: 0x0174 |            |             | Register Name: LCD_CPU_TRI5_REG                           |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 24             | R/W        | 0x0         | A1_NON_First_Valid<br>Valid in Block except first.        |
| 23:0           | R/W        | 0x0         | D23_TO_D0_NON_First_Valid<br>Valid in Block except first. |

#### 5.1.6.33 0x0180 LCD Color Map Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0180 |            |             | Register Name: LCD_CMAP_CTL_REG                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 31             | R/W        | 0x0         | COLOR_MAP_EN<br>Enable the color map function.<br>This module only works when X is divided by 4.<br>0: Bypass<br>1: Enable                                       |
| 30:1           | /          | /           | /                                                                                                                                                                |
| 0              | R/W        | 0x0         | OUT_FORMAT<br>Set the pixel output format in color map function.<br>0: 4 pixel output mode: Out0 -> Out1 -> Out2 -> Out3<br>1: 2 pixel output mode: Out0 -> Out1 |

## 5.1.6.34 0x0190 LCD Color Map Odd Line Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0190 |            |             | Register Name: LCD_CMAP_ODD0_REG                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:16          | R/W        | 0x0         | OUT_ODD1<br>Indicates the output order of components.<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved |

| Offset: 0x0190 |            |             | Register Name: LCD_CMAP_ODD0_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15:0           | R/W        | 0x0         | <p>OUT_ODD0<br/>Indicates the output order of components.</p> <p>bit15-12: Reserved</p> <p>bit11-08: Out_Odd0[23:16]</p> <p>bit07-04: Out_Odd0[15:8]</p> <p>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0</p> <p>0001: in_g0</p> <p>0010: in_r0</p> <p>0011: Reserved</p> <p>0100: in_b1</p> <p>0101: in_g1</p> <p>0110: in_r1</p> <p>0111: Reserved</p> <p>1000: in_b2</p> <p>1001: in_g2</p> <p>1010: in_r2</p> <p>1011: Reserved</p> <p>1100: in_b3</p> <p>1101: in_g3</p> <p>1110: in_r3</p> <p>1111: Reserved</p> |

## 5.1.6.35 0x0194 LCD Color Map Odd Line Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: LCD_CMAP_ODD1_REG                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:16          | R/W        | 0x0         | OUT_ODD3<br>Indicates the output order of components.<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved |

| Offset: 0x0194 |            |             | Register Name: LCD_CMAP_ODD1_REG                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:0           | R/W        | 0x0         | <p>OUT_ODD2<br/>Indicates the output order of components.<br/>bit15-12: Reserved<br/>bit11-08: Out_Odd0[23:16]<br/>bit07-04: Out_Odd0[15:8]<br/>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0<br/>0001: in_g0<br/>0010: in_r0<br/>0011: Reserved<br/>0100: in_b1<br/>0101: in_g1<br/>0110: in_r1<br/>0111: Reserved<br/>1000: in_b2<br/>1001: in_g2<br/>1010: in_r2<br/>1011: Reserved<br/>1100: in_b3<br/>1101: in_g3<br/>1110: in_r3<br/>1111: Reserved</p> |

## 5.1.6.36 0x0198 LCD Color Map Even Line Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0198 |            |             | Register Name: LCD_CMAP_EVEN0_REG                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:16          | R/W        | 0x0         | OUT_EVEN1<br>Indicates the output order of components.<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved |

| Offset: 0x0198 |            |             | Register Name: LCD_CMAP_EVENO_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:0           | R/W        | 0x0         | <p>OUT_EVENO<br/>Indicates the output order of components.</p> <p>bit15-12: Reserved</p> <p>bit11-08: Out_Odd0[23:16]</p> <p>bit07-04: Out_Odd0[15:8]</p> <p>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0</p> <p>0001: in_g0</p> <p>0010: in_r0</p> <p>0011: Reserved</p> <p>0100: in_b1</p> <p>0101: in_g1</p> <p>0110: in_r1</p> <p>0111: Reserved</p> <p>1000: in_b2</p> <p>1001: in_g2</p> <p>1010: in_r2</p> <p>1011: Reserved</p> <p>1100: in_b3</p> <p>1101: in_g3</p> <p>1110: in_r3</p> <p>1111: Reserved</p> |

## 5.1.6.37 0x019C LCD Color Map Even Line Register1 (Default Value: 0x0000\_0000)

| Offset: 0x019C |            |             | Register Name: LCD_CMAP_EVEN1_REG                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:16          | R/W        | 0x0         | OUT_EVEN3<br>Indicates the output order of components.<br>bit15-12: Reserved<br>bit11-08: Out_Odd0[23:16]<br>bit07-04: Out_Odd0[15:8]<br>bit03-00: Out_Odd0[7:0]<br>0000: in_b0<br>0001: in_g0<br>0010: in_r0<br>0011: Reserved<br>0100: in_b1<br>0101: in_g1<br>0110: in_r1<br>0111: Reserved<br>1000: in_b2<br>1001: in_g2<br>1010: in_r2<br>1011: Reserved<br>1100: in_b3<br>1101: in_g3<br>1110: in_r3<br>1111: Reserved |

| Offset: 0x019C |            |             | Register Name: LCD_CMAP_EVEN1_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:0           | R/W        | 0x0         | <p>OUT_EVEN2<br/>Indicates the output order of components.</p> <p>bit15-12: Reserved</p> <p>bit11-08: Out_Odd0[23:16]</p> <p>bit07-04: Out_Odd0[15:8]</p> <p>bit03-00: Out_Odd0[7:0]</p> <p>0000: in_b0<br/>0001: in_g0<br/>0010: in_r0<br/>0011: Reserved</p> <p>0100: in_b1<br/>0101: in_g1<br/>0110: in_r1<br/>0111: Reserved</p> <p>1000: in_b2<br/>1001: in_g2<br/>1010: in_r2<br/>1011: Reserved</p> <p>1100: in_b3<br/>1101: in_g3<br/>1110: in_r3<br/>1111: Reserved</p> |

#### 5.1.6.38 0x01F0 LCD Safe Period Register (Default Value: 0x0000\_0000)

| Offset: 0x01F0 |            |             | Register Name: LCD_SAFE_PERIOD_REG                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:29          | /          | /           | /                                                                                                                                                                                            |
| 28:16          | R/W        | 0x0         | <p>SAFE_PERIOD_FIFO_NUM</p> <p>When the data length in line buffer is more than SAFE_PERIOD_FIFO_NUM, the LCD controller will allow dram controller to stop working to change frequency.</p> |
| 15:4           | R/W        | 0x0         | <p>SAFE_PERIOD_LINE</p> <p>Set a fixed line and during the line time, the LCD controller allow dram controller to change frequency. The fixed line should be set in the blanking area.</p>   |
| 3              | /          | /           | /                                                                                                                                                                                            |

| Offset: 0x01F0 |            |             | Register Name: LCD_SAFE_PERIOD_REG                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 2:0            | R/W        | 0x0         | <p>SAFE_PERIOD_MODE<br/>Select the save mode</p> <p>000: unsafe<br/>001: safe<br/>010: safe at FIFO_CURR_NUM &gt; SAFE_PERIOD_FIFO_NUM<br/>011: safe at 2 and safe at sync active<br/>100: safe at line</p> |

#### 5.1.6.39 0x0220 LCD LVDS Analog Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0220 |            |             | Register Name: LCD_LVDS_ANA0_REG                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31             | R/W        | 0x0         | <p>LVDS_EN_MB<br/>Enable the bias circuit of the LVDS_Ana module.</p> <p>0: Disable<br/>1: Enable</p> |
| 30             | R/W        | 0x0         | Reserved                                                                                              |
| 29             | R/W        | 0x0         | <p>EN_LVDS<br/>Enable LVDS</p>                                                                        |
| 28             | R/W        | 0x0         | <p>EN_24M<br/>Enable the 24M clock</p>                                                                |
| 27:25          | /          | /           | /                                                                                                     |
| 24             | R/W        | 0x0         | <p>LVDS_HPREN_DRVC<br/>Enable clock channel drive</p> <p>0: Disable<br/>1: Enable</p>                 |
| 23:20          | R/W        | 0x0         | <p>LVDS_HPREN_DRV<br/>Enable data channel[3:0] drive</p> <p>0: Disable<br/>1: Enable</p>              |

| Offset: 0x0220 |            |             | Register Name: LCD_LVDS_ANA0_REG                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
| 19:17          | R/W        | 0x0         | LVDS_REG_C<br>Adjust current flowing through Rload of Rx to change the differential signals amplitude.<br>000: 216 mV<br>001: 252 mV<br>010: 276 mV<br>011: 312 mV<br>100: 336 mV<br>101: 372 mV<br>110: 395 mV<br>111: 432 mV   |
| 16             | R/W        | 0x0         | LVDS_REG_DENC<br>Choose data output or PLL test clock output in LVDS_tx.                                                                                                                                                         |
| 15:12          | R/W        | 0x0         | LVDS_REG_DEN<br>Choose data output or PLL test clock output in LVDS_tx.                                                                                                                                                          |
| 11             | /          | /           | /                                                                                                                                                                                                                                |
| 10:8           | R/W        | 0x0         | LVDS_REG_R<br>Adjust current flowing through Rload of Rx to change the common signals amplitude.<br>000: 0.925 V<br>001: 0.950 V<br>010: 0.975 V<br>011: 1.000 V<br>100: 1.025 V<br>101: 1.050 V<br>110: 1.075 V<br>111: 1.100 V |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | LVDS_REG_PLRC<br>LVDS clock channel direction.<br>0: Normal<br>1: Reverse                                                                                                                                                        |
| 3:0            | R/W        | 0x0         | LVDS_REG_PLR<br>LVDS data channel [3:0] direction.<br>0: Normal<br>1: Reverse                                                                                                                                                    |

### 5.1.6.40 0x0228 LCD FSYNC Generate Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0228 |            |             | Register Name: FSYNC_GEN_CTRL_REG                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:19          | /          | /           | /                                                                                                                                                                                |
| 18:8           | R/W        | 0x0         | SENSOR_DIS_TIME<br>Delay 0~2047 Hsync Period<br>When hsync_pol_sel is 0, the actual delay is sensor_dis_time-1.<br>When hsync_pol_sel is 1, the actual delay is sensor_dis_time. |
| 7              | /          | /           | /                                                                                                                                                                                |
| 6              | R/W        | 0x0         | SENSOR_ACT1_VALUE<br>Sensor Active1 Value<br>0: Fsync active_1 period output 0<br>1: Fsync active_1 period output 1                                                              |
| 5              | R/W        | 0x0         | SENSOR_ACT0_VALUE<br>Sensor Active0 Value<br>0: Fsync active_0 period output 0<br>1: Fsync active_0 period output 1                                                              |
| 4              | R/W        | 0x0         | SENSOR_DIS_VALUE<br>Sensor Disable Value<br>0: Fsync disable period output 0<br>1: Fsync disable period output 1                                                                 |
| 3              | /          | /           | /                                                                                                                                                                                |
| 2              | R/W        | 0x0         | H SYNC POL SEL<br>Hsync Polarity Select<br>0: Normal<br>1: Opposite hsync to hysnc counter                                                                                       |
| 1              | R/W        | 0x0         | SEL_VSYNC_EN<br>Select Vsync Enable<br>0: Select vsync falling edge to start state machine<br>1: Select vsync rising edge to start state machine                                 |
| 0              | R/W        | 0x0         | FSYNC_GEN_EN<br>Fsync Generate Enable<br>0: Disable<br>1: Enable                                                                                                                 |

### 5.1.6.41 0x022C LCD FSYNC Generate Delay Register (Default Value: 0x0000\_0000)

| Offset: 0x022C |            |             | Register Name: FSYNC_GEN_DLY_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:28          | /          | /           | /                                |

| Offset: 0x022C |            |             | Register Name: FSYNC_GEN_DLY_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 27:16          | R/W        | 0x0         | SENSOR_ACT0_TIME<br>Delay 0~4095 Pixel clk Period<br>The actual delay is sensor_act0_time+1. |
| 15:12          | /          | /           | /                                                                                            |
| 11:0           | R/W        | 0x0         | SENSOR_ACT1_TIME<br>Delay 0~4095 Pixel clk Period<br>The actual delay is sensor_act1_time+1. |

#### 5.1.6.42 0x0230 LCD Sync Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: LCD_SYNC_CTL_REG                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31:9           | /          | /           | /                                                                                                                                               |
| 8              | R/W        | 0x0         | LCD_CTRL_WORK_MODE<br>LCD Controller Work mode<br>0: Single DS1 mode<br>1: Dual DS1 mode                                                        |
| 7:5            | /          | /           | /                                                                                                                                               |
| 4              | R/W        | 0x0         | LCD_CYRL_SYNC_MASTER_SLAVE<br>LCD Controller Sync Master Slave<br>0: Master<br>1: Slave<br><b>Note: Only use in Single DS1 mode.</b>            |
| 3:1            | /          | /           | /                                                                                                                                               |
| 0              | R/W        | 0x0         | LCD_CTRL_SYNC_MODE<br>LCD Controller Sync Mode<br>0: Sync in the first time<br>1: Sync every frame<br><b>Note: Only use in Single DS1 mode.</b> |

#### 5.1.6.43 0x0234 LCD Sync Position Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: LCD_SYNC_POS_REG |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:28          | /          | /           | /                               |

| Offset: 0x0234 |            |             | Register Name: LCD_SYNC_POS_REG                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27:16          | R/W        | 0x0         | <p>LCD_Sync_Pixel_Num<br/>Set the pixel number of master LCD controller which is used to trigger the slave LCD controller to start working. This value is the number of pixels between the trigger point and the end of the line.</p> <p>Tri pos =<br/><math>Tline * LCD_Sync_Line_Num + Tpixel * (HT - LCD_Sync_Pixel_Num)</math></p> <p><b>Note: Only use in Single DS1 mode.</b></p>                     |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11:0           | R/W        | 0x0         | <p>LCD_Sync_Line_Num<br/>Set the line number of master LCD controller which is used to trigger the slave LCD controller to start working.</p> <p>Note: It is only set in master LCD controller. It is not necessarily to set in slave LCD controller.</p> <p>Tri pos =<br/><math>Tline * LCD_Sync_Line_Num + Tpixel * (HT - LCD_Sync_Pixel_Num)</math></p> <p><b>Note: Only use in Single DS1 mode.</b></p> |

#### 5.1.6.44 0x0238 LCD Slave Stop Position Register (Default Value: 0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: LCD_SLAVE_STOP_POS_REG                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                  |
| 7:0            | R/W        | 0x0         | <p>STOP_VAL<br/>Set the stop position of the slave LCD. This value is the number of pixels between the stop position and the end of the HFP.</p> <p>Stop_pos = HFP - Stop_val.<br/><math>0 &lt; Stop\_pos &lt; HFP - 2</math></p> <p><b>Note: Only use in Single DS1 mode.</b></p> |

#### 5.1.6.45 0x0400-0x07FF LCD Gamma Table Registers (Default Value: 0x0000\_0000)

| Offset: 0x0400-0x07FF |            |             | Register Name: LCD_GAMMA_TABLE_REG |
|-----------------------|------------|-------------|------------------------------------|
| Bit                   | Read/Write | Default/Hex | Description                        |
| 31:24                 | /          | /           | /                                  |
| 23:16                 | R/W        | 0x0         | RED_COMP<br>Red Component          |

| Offset: 0x0400–0x07FF |            |             | Register Name: LCD_GAMMA_TABLE_REG |
|-----------------------|------------|-------------|------------------------------------|
| Bit                   | Read/Write | Default/Hex | Description                        |
| 15:8                  | R/W        | 0x0         | GREEN_COMP<br>Green Component      |
| 7:0                   | R/W        | 0x0         | BLUE_COMP<br>Blue Component        |

## 5.2 TCON TV

### 5.2.1 Overview

The Timing Controller\_TV (TCON\_TV) is a module that processes video signals received from systems using a complicated arithmetic and then generates control signals and transmits them to the TV panel driver IC.

The TCON\_TV includes the following features:

- Supports 10-bit pixel depth YUV444, and HV format output up to 4K@60Hz
- Supports 8-bit pixel depth YUV444, and HV format output up to 4K@60Hz

### 5.2.2 Functional Description

#### 5.2.2.1 CEU Module

Function: This module enhance color data from DE .

$$R' = Rr * R + Rg * G + Rb * B$$

$$G' = Gr * R + Gg * G + Gb * B$$

$$B' = Br * R + Bg * G + Bb * B$$

Rr, Rg, Rb, ,Gr, Gg, Gb, Br, Bg, Bb      bool      0,1

R, G, B      u10      [0-1023]

R' have the range of      [Rmin ,Rmax]

G' have the range of      [Rmin ,Rmax]

B' have the range of      [Rmin ,Rmax]

### 5.2.3 Register List

| Module Name | Base Address |
|-------------|--------------|
| TCON_TV0    | 0x05470000   |

| Register Name  | Offset | Description                   |
|----------------|--------|-------------------------------|
| TV_GCTL_REG    | 0x0000 | TV Global Control Register    |
| TV_GINT0_REG   | 0x0004 | TV Global Interrupt Register0 |
| TV_GINT1_REG   | 0x0008 | TV Global Interrupt Register1 |
| TV_SRC_CTL_REG | 0x0040 | TV Source Control Register    |

| Register Name          | Offset                | Description                         |
|------------------------|-----------------------|-------------------------------------|
| TV_CTL_REG             | 0x0090                | TV Control Register                 |
| TV_BASIC0_REG          | 0x0094                | TV Basic Timing Register0           |
| TV_BASIC1_REG          | 0x0098                | TV Basic Timing Register1           |
| TV_BASIC2_REG          | 0x009C                | TV Basic Timing Register2           |
| TV_BASIC3_REG          | 0x00A0                | TV Basic Timing Register3           |
| TV_BASIC4_REG          | 0x00A4                | TV Basic Timing Register4           |
| TV_BASIC5_REG          | 0x00A8                | TV Basic Timing Register5           |
| TV_IO_POL_REG          | 0x0088                | TV SYNC Signal Polarity Register    |
| TV_IO_TRI_REG          | 0x008C                | TV SYNC Signal IO Control Register  |
| TV_DEBUG_REG           | 0x00FC                | TV Debug Register                   |
| TV_CEU_CTL_REG         | 0x0100                | TV CEU Control Register             |
| TV_CEU_COEF_MUL_REG    | 0x0110+N*0x04(N=0~10) | TV CEU Coefficient Register0        |
| TV_CEU_COEF_RANG_REG   | 0x0140+N*0x04(N=0~2)  | TV CEU Coefficient Register2        |
| TV_SAFE_PERIOD_REG     | 0x01F0                | TV Safe Period Register             |
| TV_FILL_CTL_REG        | 0x0300                | TV Fill Data Control Register       |
| TV_FILL_BEGIN_REG      | 0x0304+N*0x0C(N=0~2)  | TV Fill Data Begin Register         |
| TV_FILL_END_REG        | 0x0308+N*0x0C(N=0~2)  | TV Fill Data End Register           |
| TV_FILL_DATA_REG       | 0x030C+N*0x0C(N=0~2)  | TV Fill Data Value Register         |
| TV_DATA_IO_P0L0_REG    | 0x0330                | TCON Data IO Polarity Control0      |
| TV_DATA_IO_P0L1_REG    | 0x0334                | TCON Data IO Polarity Control1      |
| TV_DATA_IO_T0R0_REG    | 0x0338                | TCON Data IO Enable Control0        |
| TV_DATA_IO_T0R1_REG    | 0x033C                | TCON Data IO Enable Control1        |
| TV_PIXELDEPTH_MODE_REG | 0x0340                | TV Pixeldepth Mode Control Register |

## 5.2.4 Register Description

### 5.2.4.1 0x0000 TV Global Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TV_GCTL_REG                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31             | R/W        | 0x0         | TV_EN<br>When it is disabled, the module will be reset to idle state.<br>0: Disable<br>1: Enable                |
| 30:2           | /          | /           | /                                                                                                               |
| 1              | R/W        | 0x0         | CEC_DDC_PAD_SEL<br>CEC DDC PAD Select<br>1: TCON_TV internal pad for cec scl sal<br>0: GPIO pad for cec scl sal |
| 0              | /          | /           | /                                                                                                               |

### 5.2.4.2 0x0004 TV Global Interrupt Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TV_GINT0_REG                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31             | /          | /           | /                                                                                                                         |
| 30             | R/W        | 0x0         | TV_VB_INT_EN<br>TV Vb Interrupt Enable<br>0: Disable<br>1: Enable                                                         |
| 29             | /          | /           | /                                                                                                                         |
| 28             | R/W        | 0x0         | TV_Line_Int_En<br>TV Line Interrupt Enable<br>0: Disable<br>1: Enable                                                     |
| 27:15          | /          | /           | /                                                                                                                         |
| 14             | R/W        | 0x0         | TV_VB_INT_FLAG<br>TV Vb Interrupt Flag<br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it. |
| 13             | /          | /           | /                                                                                                                         |
| 12             | R/W        | 0x0         | TV_Line_Int_Flag<br>TV Line Interrupt Flag<br>Trigger when SY1 match the current TV scan line<br>Write 0 to clear it.     |
| 11:0           | /          | /           | /                                                                                                                         |

### 5.2.4.3 0x0008 TV Global Interrupt Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TV_GINT1_REG                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:12          | /          | /           | /                                                                                                                                                                                        |
| 11:0           | R/W        | 0           | TV_Line_Int_Num<br>Scan line for TV line trigger(including inactive lines)<br>Setting it for the specified line for trigger 1.<br>Note: SY1 is writable only when LINE_TRG1 is disabled. |

#### 5.2.4.4 0x0040 TV Source Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: TV_SRC_CTL_REG                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 31:3           | /          | /           | /                                                                                                                                                                           |
| 2:0            | R/W        | 0           | TV_SRC_SEL<br>TV Source Select<br>000: DE<br>001: Color Check<br>010: Grayscale Check<br>011: Black by White Check<br>100: Reserved<br>101: Reserved<br>111: Gridding Check |

#### 5.2.4.5 0x0090 TV Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: TV_CTL_REG                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31             | R/W        | 0x0         | TV_EN<br>When enable TCON_TV, this bit and the 0x0000[bit31] need to be enabled.<br>0: Disable<br>1: Enable                                                   |
| 30:9           | /          | /           | /                                                                                                                                                             |
| 8:4            | R/W        | 0x0         | START_DELAY<br>This is for DE0 and DE1.                                                                                                                       |
| 3:2            | /          | /           | /                                                                                                                                                             |
| 1              | R/W        | 0x0         | TV_SRC_SEL<br>TV Source Select<br>0: Reserved<br>1: BLUE data<br><b>Note: The priority of this bit is higher than TV_SRC_SEL(bit[2:0]) in TV_SRC_CTL_REG.</b> |
| 0              | /          | /           | /                                                                                                                                                             |

#### 5.2.4.6 0x0094 TV Basic Timing Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: TV_BASIC0_REG      |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:28          | /          | /           | /                                 |
| 27:16          | R/W        | 0x0         | WIDTH_XI<br>Source Width Is X+1   |
| 15:12          | /          | /           | /                                 |
| 11:0           | R/W        | 0x0         | HEIGHT_YI<br>Source Height Is Y+1 |

#### 5.2.4.7 0x0098 TV Basic Timing Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: TV_BASIC1_REG                                         |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:28          | /          | /           | /                                                                    |
| 27:16          | R/W        | 0x0         | LS_XO<br>Width Is LS_XO+1                                            |
| 15:12          | /          | /           | /                                                                    |
| 11:0           | R/W        | 0x0         | LS_YO<br>Width Is LS_YO+1<br><b>Note: This version LS_YO = TV_YI</b> |

#### 5.2.4.8 0x009C TV Basic Timing Register2 (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: TV_BASIC2_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:28          | /          | /           | /                            |
| 27:16          | R/W        | 0x0         | TV_XO<br>Width is TV_XO+1    |
| 15:12          | /          | /           | /                            |
| 11:0           | R/W        | 0x0         | TV_YO<br>Height is TV_YO+1   |

#### 5.2.4.9 0x00A0 TV Basic Timing Register3 (Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: TV_BASIC3_REG                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:29          | /          | /           | /                                                                                |
| 28:16          | R/W        | 0x0         | H_T<br>Horizontal total time<br>$\text{Thcycle} = (\text{HT}+1) * \text{Thdclk}$ |
| 15:12          | /          | /           | /                                                                                |
| 11:0           | R/W        | 0x0         | H_BP<br>Horizontal back porch<br>$\text{Thbp} = (\text{HBP}+1) * \text{Thdclk}$  |

#### 5.2.4.10 0x00A4 TV Basic Timing Register4 (Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: TV_BASIC4_REG                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:29          | /          | /           | /                                                                                        |
| 28:16          | R/W        | 0x0         | V_T<br>horizontal total time (in HD line)<br>$\text{Tvt} = \text{VT}/2 * \text{Th}$      |
| 15:12          | /          | /           | /                                                                                        |
| 11:0           | R/W        | 0x0         | V_BP<br>horizontal back porch (in HD line)<br>$\text{Tvbp} = (\text{VBP}+1) * \text{Th}$ |

#### 5.2.4.11 0x00A8 TV Basic Timing Register5 (Default Value: 0x0000\_0000)

| Offset: 0x00A8 |            |             | Register Name: TV_BASIC5_REG                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:26          | /          | /           | /                                                                                                                                  |
| 25:16          | R/W        | 0x0         | H_Spw<br>Horizontal Sync Pulse Width (in dclk)<br>$\text{Thspw} = (\text{HSPW}+1) * \text{Tdclk}$<br><b>Note: HT &gt; (HSPW+1)</b> |
| 15:10          | /          | /           | /                                                                                                                                  |

| Offset: 0x00A8 |            |             | Register Name: TV_BASIC5_REG                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 9:0            | R/W        | 0x0         | V_SPW<br>Vertical Sync Pulse Width (in lines)<br>$Tvspw = (VSPW+1) * Th$<br><b>Note:</b> VT/2 > (VSPW+1) |

#### 5.2.4.12 0x0088 TV SYNC Signal Polarity Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: TV_IO_POL_REG                        |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:28          | /          | /           | /                                                   |
| 27             | R/W        | 0x0         | IO3_INV<br>IO3 Invert<br>0: Not invert<br>1: Invert |
| 26             | R/W        | 0x0         | IO2_INV<br>IO2 Invert<br>0: Not invert<br>1: Invert |
| 25             | R/W        | 0x0         | IO1_INV<br>IO1 Invert<br>0: Not invert<br>1: Invert |
| 24             | R/W        | 0x0         | IO0_INV<br>IO0 Invert<br>0: Not invert<br>1: Invert |
| 23:0           | /          | /           | /                                                   |

#### 5.2.4.13 0x008C TV SYNC Signal IO Control Register (Default Value: 0x0F00\_0000)

| Offset: 0x008C |            |             | Register Name: TV_IO_TRI_REG                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:28          | /          | /           | /                                                                         |
| 27             | R/W        | 0x1         | IO3_OUTPUT_TRI_EN<br>IO3 Output Trigger Enable<br>1: Disable<br>0: Enable |

| Offset: 0x008C |            |             | Register Name: TV_IO_TRI_REG                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 26             | R/W        | 0x1         | IO2_OUTPUT_TRI_EN<br>IO2 Output Trigger Enable<br>1: Disable<br>0: Enable |
| 25             | R/W        | 0x1         | IO1_OUTPUT_TRI_EN<br>IO1 Output Trigger Enable<br>1: Disable<br>0: Enable |
| 24             | R/W        | 0x1         | IO0_OUTPUT_TRI_EN<br>IO0 Output Trigger Enable<br>1: Disable<br>0: Enable |
| 23:0           | /          | /           | /                                                                         |

#### 5.2.4.14 0x00FC TV Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x00FC |            |             | Register Name: TV_DEBUG_REG                                            |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31             | /          | /           | /                                                                      |
| 30             | R/W        | 0x0         | TV_FIFO_U<br>TV FIFO Underflow                                         |
| 29             | /          | /           | /                                                                      |
| 28             | R          | 0x0         | TV_FIELD_POL<br>TV Field Polarity<br>0: Second field<br>1: First field |
| 27:12          | /          | /           | /                                                                      |
| 13             | R/W        | 0x0         | LINE_BUF_BYPASS<br>Line Buffer Bypass<br>0: Used<br>1: Bypass          |
| 12             | /          | /           | /                                                                      |
| 11:0           | R          | 0x0         | TV_CURRENT_LINE<br>TV Current Line                                     |

#### 5.2.4.15 0x0100 TV CEU Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: TV_CEU_CTL_REG                  |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31             | R/W        | 0x0         | CEU_EN<br>CEU Enable<br>0: Bypass<br>1: Enable |
| 30:0           | /          | /           | /                                              |

#### 5.2.4.16 0x110+N\*0x04 (N=0~10) TV CEU Coefficient Register0 (Default Value: 0x0000\_0000)

| Offset: 0x110+N*0x04 (N=0~10) |            |             | Register Name: TV_CEU_COEF_MUL_REG                                                                                                                                                          |
|-------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:9                          | /          | /           | /                                                                                                                                                                                           |
| 8                             | R/W        | 0x0         | CEU_COEF_MUL_VALUE<br>Note:<br>1. CEU_Coef_Mul_Value only can be 0 or 1.<br>2. REG Map:<br>N=0: Rr<br>N=1: Rg<br>N=2: Rb<br>N=4: Gr<br>N=5: Gg<br>N=6: Gb<br>N=8: Br<br>N=9: Bg<br>N=10: Bb |
| 7:0                           | /          | /           | /                                                                                                                                                                                           |

#### 5.2.4.17 0x140+N\*0x04 (N=0~2) TV CEU Coefficient Register2 (Default Value: 0x0000\_0000)

| Offset: 0x140+N*0x04 (N=0~2) |            |             | Register Name: TV_CEU_COEF_RANG_REG                             |
|------------------------------|------------|-------------|-----------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                     |
| 31:26                        | /          | /           | /                                                               |
| 25:16                        | R/W        | 0           | CEU_COEF_RANGE_MIN<br>Unsigned 10-bit Value, range of [0, 1023] |
| 15:10                        | /          | /           | /                                                               |
| 9:0                          | R/W        | 0           | CEU_COEF_RANGE_MAX<br>Unsigned 10-bit Value, range of [0, 1023] |

### 5.2.4.18 0x01F0 TV Safe Period Register (Default Value: 0x0000\_0000)

| Offset: 0x01F0 |            |             | Register Name: TV_SAFE_PERIOD_REG                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:29          | /          | /           | /                                                                                                                                                                                        |
| 28:16          | R/W        | 0x0         | SAFE_PERIOD_FIFO_NUM<br>Safe Period FIFO Number                                                                                                                                          |
| 15:4           | R/W        | 0x0         | Safe_Period_Line<br>Safe Period Line                                                                                                                                                     |
| 3              | /          | /           | /                                                                                                                                                                                        |
| 2:0            | R/W        | 0x0         | Safe_Period_Mode<br>Safe Period Mode<br>000: unsafe<br>001: safe<br>010: safe at line_buf_curr_num > safe_period_fifo_num<br>011: safe at 2 and safe at sync active<br>100: safe at line |

### 5.2.4.19 0x0300 TV Fill Data Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: TV_FILL_CTL_REG                         |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31             | R/W        | 0x0         | TV_Fill_En<br>TV Fill Enable<br>0: Bypass<br>1: Enable |
| 30:0           | /          | /           | /                                                      |

### 5.2.4.20 0x0304+N\*0x0C (N=0~2) TV Fill Data Begin Register (Default Value: 0x0000\_0000)

| Offset: 0x0304+N*0x0C (N=0~2) |            |             | Register Name: TV_FILL_BEGIN_REG |
|-------------------------------|------------|-------------|----------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                      |
| 31:24                         | /          | /           | /                                |
| 23:0                          | R/W        | 0           | FILL_BEGIN<br>Fill Begin         |

#### 5.2.4.21 0x0308+N\*0x0C (N=0~2) TV Fill Data End Register (Default Value: 0x0000\_0000)

| Offset: 0x0308+N*0x0C (N=0~2) |            |             | Register Name: TV_FILL_END_REG |
|-------------------------------|------------|-------------|--------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                    |
| 31:24                         | /          | /           | /                              |
| 23:0                          | R/W        | 0x0         | FILL-END<br>Fill End           |

#### 5.2.4.22 0x030C+N\*0x0C (N=0~2) TV Fill Data Value Register (Default Value: 0x0000\_0000)

| Offset: 0x030C+N*0x0C (N=0~2) |            |             | Register Name: TV_FILL_DATA_REG |
|-------------------------------|------------|-------------|---------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                     |
| 31:30                         | /          | /           | /                               |
| 29:0                          | R/W        | 0x0         | FILL_VALUE<br>Fill Value        |

#### 5.2.4.23 0x0330 TCON Data IO Polarity Control0 (Default Value: 0x0000\_0000)

| Offset: 0x0330 |            |             | Register Name: TV_DATA_IO_POL0_REG                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:26          | /          | /           | /                                                                                               |
| 25:16          | R/W        | 0x0         | R_CB_CH_DATA_INV<br>R CB Channel Data Inv<br>0: normal polarity<br>1: invert the specify output |
| 15:10          | /          | /           | /                                                                                               |
| 9:0            | R/W        | 0x0         | G_Y_CH_DATA_INV<br>G Y Channel Data Inv<br>0: normal polarity<br>1: invert the specify output   |

#### 5.2.4.24 0x0334 TCON Data IO Polarity Control1 (Default Value: 0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: TV_DATA_IO_POL1_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:26          | /          | /           | /                                  |

| Offset: 0x0334 |            |             | Register Name: TV_DATA_IO_POL1_REG                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 25:16          | R/W        | 0x0         | B_CR_CH_DATA_INV<br>B CR CHANNEL DATA INV<br>0: Normal polarity<br>1: Invert the specify output |
| 15:0           | /          | /           | /                                                                                               |

#### 5.2.4.25 0x0338 TCON Data IO Enable Control0 (Default Value: 0x03FF\_03FF)

| Offset: 0x0338 |            |             | Register Name: TV_DATA_IO_TRI0_REG                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:26          | /          | /           | /                                                                                             |
| 25:16          | R/W        | 0x3ff       | R_CB_CH_DATA_OUT_TRI_EN<br>R CB Channel Data Output Trigger Enable<br>1: Disable<br>0: Enable |
| 15:10          | /          | /           | /                                                                                             |
| 9:0            | R/W        | 0x3ff       | G_Y_CH_DATA_OUT_TRI_EN<br>G Y Channel Data Output Trigger Enable<br>1: Disable<br>0: Enable   |

#### 5.2.4.26 0x033C TCON Data IO Enable Control1 (Default Value: 0x03FF\_0000)

| Offset: 0x033C |            |             | Register Name: TV_DATA_IO_TRI1_REG                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:26          | /          | /           | /                                                                                             |
| 25:16          | R/W        | 0x3ff       | B_CR_CH_DATA_OUT_TRI_EN<br>B CR Channel Data Output Trigger Enable<br>1: Disable<br>0: Enable |
| 15:0           | /          | /           | /                                                                                             |

#### 5.2.4.27 0x0340 TV Pixeldepth Mode Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: TV_PIXELDEPTH_MODE_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                        |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                  |
| 0              | R/W        | 0x0         | COLORBAR_PD_MODE<br>Colorbar Pixeldepth mode<br>0: 8-bit mode<br>When data source is the embedded colorbar, the 8-bit colorbar pattern is transmitted.<br>1: 10-bit mode<br>When data source is the embedded colorbar, the 10-bit colorbar pattern is transmitted. |

## 5.3 TV Encoder

### 5.3.1 Overview

The TV Encoder (TVE) module is a highly programmable digital video encoder supporting worldwide video standards Composite Video Broadcast Signal (CVBS).

The TVE includes the following features:

- 1-channel CVBS output, supporting PAL-D and NTSC-M
- Plug status auto detecting
- 10 bits DAC output

### 5.3.2 Block Diagram

Figure 5-14 shows a block diagram of the TVE.

**Figure 5-14 TVE Block Diagram**



### 5.3.3 Functional Description

#### 5.3.3.1 External Signals

Table 5-11 describes the external signals of TVE.

**Table 5-11 TVE External Signals**

| Port Name | Description    | Type |
|-----------|----------------|------|
| TVOUT0    | TV CVBS output | AO   |
| VCC-TVOUT | TV DAC power   | P    |

### 5.3.3.2 Clock Sources

The TVE module requires one clock with 50% duty. Digital circuit and Analog circuit work by this clock. Mode and Clock frequency is shown below.

Table 5-12 TVE Clock Sources

| Mode | TVE Clock Frequency |
|------|---------------------|
| NTSC | 216 MHz             |
| PAL  | 216 MHz             |

### 5.3.3.3 Auto Detection Function

Figure 5-15 Auto Detection Function



DAC outputs constant current, when insert, external load is  $37.5\Omega$ ; when pull out, external load is  $75\Omega$ . The method that comparator judges pin level can detect plug action.

Because plug action may exist jitter, then there need be a filter to filter jitter, the debounce time of filter is set through the bit[3:0] of TV Encoder Auto Detection de-bounce Setting Register.

The pulse cycle time can be set through the bit[30:16] of TV Encoder Auto Detect Configuration Register1, the pulse start time can be set through the bit[14:0] of TV Encoder Auto Detect Configuration Register1. The clock sources of the two time are 32KHz clock.

Pulse width is cycle time of 4 clock sources.

Pulse amplitude can be set through the bit[9:0] of TV Encoder Auto Detect Configuration Register0.

### 5.3.3.4 DAC Calibration Function

Figure 5-16 DAC Calibration Function



After FT, 10-bit calibration value is burned into efuse. Every time software can read the 10-bit calibration value from efuse, to control BIAS current and BIAS current switch, then a specific BIAS current is generated to calibrate maximum output voltage of DAC.

### 5.3.4 Programming Guidelines

#### 5.3.4.1 Operating TVE Module

Operate TVE module by the following steps, Figure 5-17 shows the process diagram.

- Step 1** Set CCU clock source for TVE, and release AHB bus, and module reset.
- Step 2** Initial DAC amplitude value from efuse calibration value which has burned.
- Step 3** Enable the plug-in detect function, and detect plug-in status every 200 ms.
- Step 4** When the plug-in has detected, configure TVE module to output mode setting by application.

**Figure 5-17 Operating TVE Module**

### 5.3.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| TVE_TOP     | 0x05600000   |
| TVE         | 0x05604000   |

| Register Name  | Offset | Description                       |
|----------------|--------|-----------------------------------|
| <b>TVE_TOP</b> |        |                                   |
| TVE_DAC_MAP    | 0x0020 | TV Encoder DAC MAP Register       |
| TVE_DAC_STATUS | 0x0024 | TV Encoder DAC STAUTS Register    |
| TVE_DAC_CFG0   | 0x0028 | TV Encoder DAC CFG0 Register      |
| TVE_DAC_CFG1   | 0x002C | TV Encoder DAC CFG1 Register      |
| TVE_DAC_CFG2   | 0x0030 | TV Encoder DAC CFG2 Register      |
| TVE_DAC_CFG3   | 0x0034 | TV Encoder DAC CFG2 Register      |
| TVE_DAC_TEST   | 0x00F0 | TV Encoder DAC TEST Register      |
| <b>TVE</b>     |        |                                   |
| TVE_000_REG    | 0x0000 | TV Encoder Clock Gating Register  |
| TVE_004_REG    | 0x0004 | TV Encoder Configuration Register |
| TVE_008_REG    | 0x0008 | TV Encoder DAC Register1          |

| Register Name | Offset | Description                                               |
|---------------|--------|-----------------------------------------------------------|
| TVE_00C_REG   | 0x000C | TV Encoder Notch and DAC Delay Register                   |
| TVE_010_REG   | 0x0010 | TV Encoder Chroma Frequency Register                      |
| TVE_014_REG   | 0x0014 | TV Encoder Front/Back Porch Register                      |
| TVE_018_REG   | 0x0018 | TV Encoder HD Mode VSYNC Register                         |
| TVE_01C_REG   | 0x001C | TV Encoder Line Number Register                           |
| TVE_020_REG   | 0x0020 | TV Encoder Level Register                                 |
| TVE_024_REG   | 0x0024 | TV Encoder DAC Register2                                  |
| TVE_030_REG   | 0x0030 | TV Encoder Auto Detection Enable Register                 |
| TVE_034_REG   | 0x0034 | TV Encoder Auto Detection Interrupt Status Register       |
| TVE_038_REG   | 0x0038 | TV Encoder Auto Detection Status Register                 |
| TVE_03C_REG   | 0x003C | TV Encoder Auto Detection De-bounce Setting Register      |
| TVE_0F8_REG   | 0x00F8 | TV Encoder Auto Detect Configuration Register0            |
| TVE_OFC_REG   | 0x00FC | TV Encoder Auto Detect Configuration Register1            |
| TVE_100_REG   | 0x0100 | TV Encoder Color Burst Phase Reset Configuration Register |
| TVE_104_REG   | 0x0104 | TV Encoder VSYNC Number Register                          |
| TVE_108_REG   | 0x0108 | TV Encoder Notch Filter Frequency Register                |
| TVE_10C_REG   | 0x010C | TV Encoder Cb/Cr Level/Gain Register                      |
| TVE_110_REG   | 0x0110 | TV Encoder Tint and Color Burst Phase Register            |
| TVE_114_REG   | 0x0114 | TV Encoder Burst Width Register                           |
| TVE_118_REG   | 0x0118 | TV Encoder Cb/Cr Gain Register                            |
| TVE_11C_REG   | 0x011C | TV Encoder Sync and VBI Level Register                    |
| TVE_120_REG   | 0x0120 | TV Encoder White Level Register                           |
| TVE_124_REG   | 0x0124 | TV Encoder Video Active Line Register                     |
| TVE_128_REG   | 0x0128 | TV Encoder Video Chroma BW and CompGain Register          |
| TVE_12C_REG   | 0x012C | TV Encoder Register                                       |
| TVE_130_REG   | 0x0130 | TV Encoder Re-sync Parameters Register                    |
| TVE_134_REG   | 0x0134 | TV Encoder Slave Parameter Register                       |
| TVE_138_REG   | 0x0138 | TV Encoder Configuration Register0                        |
| TVE_13C_REG   | 0x013C | TV Encoder Configuration Register1                        |
| TVE_380_REG   | 0x0380 | TV Encoder Low Pass Control Register                      |
| TVE_384_REG   | 0x0384 | TV Encoder Low Pass Filter Control Register               |

| Register Name | Offset | Description                                |
|---------------|--------|--------------------------------------------|
| TVE_388_REG   | 0x0388 | TV Encoder Low Pass Gain Register          |
| TVE_38C_REG   | 0x038C | TV Encoder Low Pass Gain Control Register  |
| TVE_390_REG   | 0x0390 | TV Encoder Low Pass Shoot Control Register |
| TVE_394_REG   | 0x0394 | TV Encoder Low Pass Coring Register        |
| TVE_3A0_REG   | 0x03A0 | TV Encoder Noise Reduction Register        |

### 5.3.6 TVE\_TOP Register Description

#### 5.3.6.1 0x0020 TV Encoder DAC MAP Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: TVE_DAC_MAP                                          |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:7           | /          | /           | /                                                                   |
| 6:4            | R/W        | 0x0         | DAC_MAP<br>000: OUT0<br>Others: Reserved                            |
| 3:2            | /          | /           | /                                                                   |
| 1:0            | R/W        | 0x0         | DAC_SEL<br>00: Reserved<br>01: TVE0<br>10: Reserved<br>11: Reserved |

#### 5.3.6.2 0x0024 TV Encoder DAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: TVE_DAC_STATUS                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:2           | /          | /           | /                                                                                     |
| 1:0            | R          | 0x0         | DAC_Status<br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |

### 5.3.6.3 0x0028 TV Encoder DAC Configuration0 Register (Default Value: 0x8000\_4200)

| Offset: 0x0028 |            |             | Register Name: TVE_DAC_CFG0                                  |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31             | R/W        | 0x1         | DAC_CLOCK_INVERT<br>0: Not invert<br>1: Invert               |
| 30:26          | /          | /           | /                                                            |
| 25:16          | R/W        | 0x0         | CALI_IN                                                      |
| 15:12          | R/W        | 0x4         | LOW_BIAS<br>500 uA to 4 mA                                   |
| 11:10          | /          | /           | /                                                            |
| 9              | R/W        | 0x1         | BIAS_EXT_SEL<br>0: Disable<br>1: Enable<br>(A_SEL_BIAS_ADDA) |
| 8              | R/W        | 0x0         | BIAS_INT_SEL<br>0: Disable<br>1: Enable<br>(A_SEL_BIAS_RES)  |
| 7:5            | /          | /           | /                                                            |
| 4              | R/W        | 0x0         | BIAS_REF_INT_EN<br>0: Disable<br>1: Enable<br>(A_EN_RESREF)  |
| 3:1            | /          | /           | /                                                            |
| 0              | R/W        | 0x0         | DAC_EN<br>0: Disable<br>1: Enable                            |

### 5.3.6.4 0x002C TV Encoder DAC Configuration1 Register (Default Value: 0x0000\_023A)

| Offset: 0x002C |            |             | Register Name: TVE_DAC_CFG1 |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:10          | /          | /           | /                           |
| 9              | R/W        | 0x1         | REF_EXT_SEL<br>0: Disable   |

| Offset: 0x002C |            |             | Register Name: TVE_DAC_CFG1                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | 1: Enable<br>(A_SEL_DETREF_LDO)                                                                                                                                                                                                                                                                                                                              |
| 8              | R/W        | 0x0         | REF_INT_SEL<br>0: Disable<br>1: Enable<br>(A_SEL_DETREF_RES)                                                                                                                                                                                                                                                                                                 |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 5:4            | R/W        | 0x3         | REF2_SEL<br>00: 0.25 V<br>01: 0.30 V<br>10: 0.35 V<br>11: 0.40 V<br>(a_refslct2<1:0>)                                                                                                                                                                                                                                                                        |
| 3:0            | R/W        | 0xA         | REF1_SEL<br>0000: 0.50 V<br>0001: 0.55 V<br>0010: 0.60 V<br>0011: 0.65 V<br>0100: 0.70 V<br>0101: 0.75 V<br>0110: 0.80 V<br>0111: 0.85 V<br>1000: 0.90 V<br>1001: 0.95 V<br>1010: 1.00 V<br>1011: 1.05 V<br>1100: 1.10 V<br>1101: 1.15 V<br>1110: 1.20 V<br>1111: 1.25 V<br>(a_refslct1<3:0>)<br>The reference voltage is used for hot plug detect function. |

### 5.3.6.5 0x0030 TV Encoder DAC Configuration2 Register (Default Value: 0x0000\_0010)

| Offset: 0x0030 |            |             | Register Name: TVE_DAC_CFG2                                 |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:13          | /          | /           | /                                                           |
| 12:8           | R/W        | 0x0         | AB<br>( I config output current for different peak voltage) |
| 7:6            | R/W        | 0x0         | S2S1                                                        |
| 5:0            | R/W        | 0x10        | R_SET                                                       |

### 5.3.6.6 0x0034 TV Encoder DAC Configuration3 Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: TVE_DAC_CFG3                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:26          | /          | /           | /                                                                                    |
| 25:16          | R/W        | 0x0         | FORCE_DATA_SET<br>Force DAC input data                                               |
| 15:1           | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | FORCE_DATA_EN<br>0: DAC input data from TVE<br>1: DAC input data from FORCE_DATA_SET |

### 5.3.6.7 0x00F0 TV Encoder DAC Test Register (Default Value: 0x0000\_0000)

| Offset: 0x00F0 |            |             | Register Name: TVE_DAC_TEST                  |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:26          | /          | /           | /                                            |
| 25:16          | R/W        | 0x0         | DAC_TEST_LENGTH<br>DAC TEST DATA LENGTH      |
| 15:6           | /          | /           | /                                            |
| 5:4            | R/W        | 0x0         | DAC_TEST_SEL<br>00: DAC0<br>Others: Reserved |
| 3:1            | /          | /           | /                                            |
| 0              | R/W        | 0x0         | DAC_TEST_ENABLE<br>0: Reserved               |

| Offset: 0x00F0 |            |             | Register Name: TVE_DAC_TEST      |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
|                |            |             | 1: Repeat DAC data from DAC sram |

### 5.3.7 TVE Register Description

#### 5.3.7.1 0x0000 TV Encoder Clock Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TVE_000_REG                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31             | R/W        | 0x0         | CLOCK_GATE_DIS<br>0: Enable<br>1: Disable                                                                             |
| 30:29          | /          | /           | /                                                                                                                     |
| 28             | R/W        | 0x0         | BIST_EN<br>0: Normal mode<br>1: Bist mode                                                                             |
| 27:23          | /          | /           | /                                                                                                                     |
| 22             | R/W        | 0x0         | UPSAMPLE_FOR_YPBPR<br>0: 1x<br>1: 2x                                                                                  |
| 21:20          | R/W        | 0x0         | UPSAMPLE_FOR_CVBS<br>Out up sample<br>00: 27 MHz<br>01: 54 MHz<br>10: 108 MHz<br>11: 216 MHz                          |
| 19:1           | /          | /           | /                                                                                                                     |
| 0              | R/W        | 0x0         | TVE_EN<br>0: Disable<br>1: Enable<br>Video Encoder enable, default disable, write 1 to take it out of the reset state |

### 5.3.7.2 0x0004 TV Encoder Configuration Register (Default Value: 0x0001\_0000)

| Offset: 0x0004 |            |             | Register Name: TVE_004_REG                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                          |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                    |
| 29             | R/W        | 0x0         | <p>BYPASS_TV</p> <p>0: Disable<br/>1: Enable</p>                                                                                                                                                                                     |
| 28:27          | R/W        | 0x0         | <p>DAC_Src_Sel</p> <p>00: TV Encoder<br/>01: LCD controller, override all other TV encoder setting, the DAC clock can from LCD controller.<br/>10: DAC test mode, DAC using DAC clock<br/>11: DAC test mode, DAC using AHB clock</p> |
| 26             | R/W        | 0x0         | <p>DAC_Control_Logic_Clock_Sel</p> <p>0: Using 27 MHz clock or 74.25 MHz clock depend on CCU setting<br/>1: Using 54 MHz clock or 148.5 MHz clock depend on CCU setting</p>                                                          |
| 25             | R/W        | 0x0         | <p>Core_Datapath_Logic_Clock_Sel</p> <p>0: Using 27 MHz clock or 74.25 MHz clock depend on CCU setting<br/>1: Using 54 MHz clock or 148.5 MHz clock depend on CCU setting</p>                                                        |
| 24             | R/W        | 0x0         | <p>Core_Control_Logic_Clock_Sel</p> <p>0: Using 27 MHz clock or 74.25 MHz clock depend on CCU setting<br/>1: Using 54 MHz clock or 148.5 MHz clock depend on CCU setting</p>                                                         |
| 23:21          | /          | /           | /                                                                                                                                                                                                                                    |
| 20             | R/W        | 0x0         | <p>Cb_Cr_Seq_For_422_Mode</p> <p>0: Cb first<br/>1: Cr first</p>                                                                                                                                                                     |
| 19             | R/W        | 0x0         | <p>Input_Chroma_Data_Sampling_Rate_Sel</p> <p>0: 4:4:4<br/>1: 4:2:2</p>                                                                                                                                                              |
| 18             | R/W        | 0x0         | <p>YUV_RGB_Output_En</p> <p>0: CVBS<br/>1: Reserved</p>                                                                                                                                                                              |

| Offset: 0x0004 |            |             | Register Name: TVE_004_REG                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 17             | R/W        | 0x0         | <p>YC_EN</p> <p>S-port Video enable Selection.</p> <p>0: Y/C is disable<br/>1: Reserved</p> <p>This bit selects whether the S-port(Y/C) video output is enabled or disabled.</p>                                                                                                                                                                                 |
| 16             | R/W        | 0x1         | <p>CVBS_EN</p> <p>Composite video enables selection</p> <p>0: Composite video is disabled, Only Y/C is enabled<br/>1: Composite video is enabled., CVBS and Y/C are enabled</p> <p>This bit selects whether the composite video output (CVBS) is enabled or disabled.</p>                                                                                        |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 9              | R/W        | 0x0         | <p>Color_BAR_TYPE</p> <p>0: 75/7.5/75/7.5 (NTSC), 100/0/75/0(PAL)<br/>1: 100/7.5/100/7.5(NTSC), 100/0/100/0(PAL)</p>                                                                                                                                                                                                                                             |
| 8              | R/W        | 0x0         | <p>Color_BAR_MODE</p> <p>Standard Color bar input selection</p> <p>0: The Video Encoder input is coming from the Display Engineer<br/>1: The Video Encoder input is coming from an internal standard color bar generator.</p> <p>This bit selects whether the Video Encoder video data input is replaced by an internal standard color bar generator or not.</p> |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | <p>Mode_1080i_1250Line_Sel</p> <p>0: 1125 Line mode<br/>1: 1250 Line mode</p>                                                                                                                                                                                                                                                                                    |
| 3:0            | R/W        | 0x0         | <p>TVMode_Select</p> <p>0000: NTSC<br/>0001: PAL<br/>0010: Reserved<br/>0011: Reserved<br/>01xx: Reserved<br/>100x: Reserved<br/>101x: Reserved<br/>110x: Reserved</p>                                                                                                                                                                                           |

| Offset: 0x0004 |            |             | Register Name: TVE_004_REG                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
|                |            |             | 111x: Reserved<br>Note: Changing this register value will cause some relative register setting to relative value. |

### 5.3.7.3 0x0008 TV Encoder DAC Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TVE_008_REG                         |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:7           | /          | /           | /                                                  |
| 6:4            | R/W        | 0x0         | DAC0_Src_Sel<br>000: Composite<br>Others: Reserved |
| 3:0            | /          | /           | /                                                  |

### 5.3.7.4 0x000C TV Encoder Notch and DAC Delay Register (Default Value: 0x0201\_4924)

| Offset: 0x000C |            |             | Register Name: TVE_00C_REG                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31             | R/W        | 0x0         | Chroma_Filter_Active_Valid<br>0: Disable<br>1: Enable                                     |
| 30             | R/W        | 0x0         | Luma_filter_lti_enable<br>0: Disable Luma filter lti<br>1: Enable Luma filter lti         |
| 27:25          | R/W        | 0x1         | Y_DELAY_BEFORE_DITHER                                                                     |
| 24             | R/W        | 0x0         | HD_Mode_CB_Filter_Bypass<br>0: Bypass Enable<br>1: Bypass Disable                         |
| 23             | R/W        | 0x0         | HD_Mode_CR_Filter_Bypass<br>0: Bypass Enable<br>1: Bypass Disable                         |
| 22             | R/W        | 0x0         | Chroma_Filter_1_444_En<br>0: Chroma Filter 1 444 Disable<br>1: Chroma Filter 1 444 Enable |
| 21             | R/W        | 0x0         | Chroma_HD_Mode_Filter_En                                                                  |

| Offset: 0x000C |            |             | Register Name: TVE_00C_REG                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
|                |            |             | 0: Chroma HD Filter Disable<br>1: Chroma HD Filter Enable                                                                                                                                                    |
| 20             | R/W        | 0x0         | Chroma_Filter_Stage_1_Bypass<br>0: Chroma Filter Stage 1 Enable<br>1: Chroma Filter Stage 1 bypass                                                                                                           |
| 19             | R/W        | 0x0         | Chroma_Filter_Stage_2_Bypass<br>0: Chroma Filter Stage 2 Enable<br>1: Chroma Filter Stage 2 bypass                                                                                                           |
| 18             | R/W        | 0x0         | Chroma_Filter_Stage_3_Bypass<br>0: Chroma Filter Stage 3 Enable<br>1: Chroma Filter Stage 3 bypass                                                                                                           |
| 17             | R/W        | 0x0         | Luma_Filter_Bypass<br>0: Luma Filter Enable<br>1: Luma Filter bypass                                                                                                                                         |
| 16             | R/W        | 0x1         | Notch_El<br>0: The luma notch filter is bypassed<br>1: The luma notch filter is operating<br>Luma notch filter on/off selection<br>Note: This bit selects if the luma notch filter is operating or bypassed. |
| 15:12          | R/W        | 0x4         | C_DELAY_BEFORE_DITHER                                                                                                                                                                                        |
| 11:0           | R/W        | 0x924       | Reserved                                                                                                                                                                                                     |

### 5.3.7.5 0x0010 TV Encoder Chroma Frequency Register (Default Value: 0x21F0\_7C1F)

| Offset: 0x0010 |            |             | Register Name: TVE_010_REG                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W        | 0x21f07c1f  | Chroma_Freq<br>Specify the ratio between the color burst frequency. 32 bits unsigned fraction. The default value is h21f07c1f, which is compatible with NTSC spec.<br>3.5795455 MHz (X'21F07C1F'): NTSC-M, NTSC-J<br>4.43361875 MHz(X'2A098ACB'): PAL-B, D, G, H,I, N<br>3.582056 MHz (X'21F69446'): PAL-N(Argentina)<br>3.579611 MHz (X'21E6EFE3'): PAL-M |

### 5.3.7.6 0x0014 TV Encoder Front/Back Porch Register (Default Value: 0x0076\_0020)

| Offset: 0x0014 |            |             | Register Name: TVE_014_REG                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 24:16          | R/W        | 0x76        | <p>Back_Porch</p> <p>Specify the width of the back porch in encoder clock cycles.</p> <p>Min value is (burst_width+breeze_way+17). 8 bits unsigned integer.</p> <p>The default value is 118.</p> <p>For 720p mode, the value is 260.</p> <p>For 1080i/p mode, the value is 192.</p> |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 11:0           | R/W        | 0x20        | <p>Front_Porch</p> <p>Must be even</p> <p>Specify the width of the front porch in encoder clock cycles.</p> <p>6 bits unsigned even integer. Allowed range is form 10 to 62.</p> <p>The default value is 32.</p> <p>For 1080i mode, the value is 44.</p>                            |

### 5.3.7.7 0x0018 TV Encoder HD Mode VSYNC Register (Default Value: 0x0000\_0016)

| Offset: 0x0018 |            |             | Register Name: TVE_018_REG               |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |
| 31:28          | /          | /           | /                                        |
| 27:16          | R/W        | 0x0         | Broad_Plus_Cycle_Number_In_HD_Mode_VSYNC |
| 15:12          | /          | /           | /                                        |
| 11:0           | R/W        | 0x16        | Front_Porch_Like_In_HD_Mode_VSYNC        |

### 5.3.7.8 0x001C TV Encoder Line Number Register (Default Value: 0x0016\_020D)

| Offset: 0x001C |            |             | Register Name: TVE_01C_REG                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:24          | /          | /           | /                                                                                                                                  |
| 23:16          | R/W        | 0x16        | <p>First_Video_Line</p> <p>Specify the index of the first line in a field/frame to have active video. 8 bits unsigned integer.</p> |

| Offset: 0x001C |            |             | Register Name: TVE_01C_REG                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
|                |            |             | For interlaced video: When VSync5=B'0', FirstVideoLine is restricted to be greater than 7. When VSync5=B'1', FirstVideoLine is restricted to be greater than 9. |
| 15:11          | /          | /           | /                                                                                                                                                               |

  

| Offset: 0x0020 |            |             | Register Name: TVE_020_REG                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:26          | /          | /           | /                                                                                                                                   |
| 25:16          | R/W        | 0xf0        | Blank_Level<br>Specify the blank level setting for active lines. This is 10 bits unsigned integer. Allowed range is from 0 to 1023. |
| 15:10          | /          | /           | /                                                                                                                                   |
| 9:0            | R/W        | 0x11a       | Black_Level<br>Specify the black level setting. This is 10 bits unsigned integer. Allowed range is from 240 to 1023.                |

### 5.3.7.9 0x0020 TV Encoder Level Register (Default Value: 0x00F0\_011A)

| Offset: 0x0020 |            |             | Register Name: TVE_020_REG                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:26          | /          | /           | /                                                                                                                                   |
| 25:16          | R/W        | 0xf0        | Blank_Level<br>Specify the blank level setting for active lines. This is 10 bits unsigned integer. Allowed range is from 0 to 1023. |
| 15:10          | /          | /           | /                                                                                                                                   |
| 9:0            | R/W        | 0x11a       | Black_Level<br>Specify the black level setting. This is 10 bits unsigned integer. Allowed range is from 240 to 1023.                |

### 5.3.7.10 0x0030 TV Encoder Auto Detection Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: TVE_030_REG                             |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31             | R/W        | 0x0         | DAC_AUTO_DETECT_MODE_SEL<br>0: Old Mode<br>1: New Mode |
| 30:17          | /          | /           | /                                                      |
| 16             | R/W        | 0x0         | DAC0_Auto_Detect_Interrupt_En                          |
| 15:1           | /          | /           | /                                                      |
| 0              | R/W        | 0x0         | DAC0_Auto_Detect_Enable                                |

### 5.3.7.11 0x0034 TV Encoder Auto Detection Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: TVE_034_REG                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:1           | /          | /           | /                                                                                           |
| 0              | R/W1C      | 0x0         | DAC0_Auto_Detect_Interrupt_Active_Flag<br>Write 1 to inactive DAC0 auto detection interrupt |

### 5.3.7.12 0x0038 TV Encoder Auto Detection Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: TVE_038_REG                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:2           | /          | /           | /                                                                                      |
| 1:0            | R          | 0x0         | DAC0_Status<br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |

### 5.3.7.13 0x003C TV Encoder Auto Detection Debounce Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: TVE_03C_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:26          | /          | /           | /                          |

| Offset: 0x003C |            |             | Register Name: TVE_03C_REG                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 25:16          | R/W        | 0x0         | DAC_TEST_REGISTER<br>DAC test register.                                  |
| 15:4           | /          | /           | /                                                                        |
| 3:0            | R/W        | 0x0         | DAC0_De_Bounce_Times<br>The de_bounce time for hot plug detect function. |

### 5.3.7.14 0x00F8 TV Encoder Auto Detection Configuration Register0 (Default Value: 0x0000\_0000)

| Offset: 0x00F8 |            |             | Register Name: TVE_OF8_REG                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:10          | /          | /           |                                                                                             |
| 9:0            | R/W        | 0x0         | DETECT_Pulse_Value<br>Use for DAC data input at auto detect pluse. Set the pulse amplitude. |

### 5.3.7.15 0x00FC TV Encoder Auto Detection Configuration Register1 (Default Value: 0x0000\_0000)

| Offset: 0x00FC |            |             | Register Name: TVE_OFC_REG                     |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31             | /          | /           | /                                              |
| 30:16          | R/W        | 0x0         | DETECT_Pulse_Periods<br>Use 32K clock          |
| 15             | /          | /           | /                                              |
| 14:0           | R/W        | 0x0         | DETECT_Pulse_Start<br>Detect signal start time |

### 5.3.7.16 0x0100 TV Encoder Color Burst Phase Reset Configuration Register (Default Value: 0x0000\_0001)

| Offset: 0x0100 |            |             | Register Name: TVE_100_REG                              |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:2           | /          | /           | /                                                       |
| 1:0            | R/W        | 0x1         | Color_Phase_Reset<br>Color burst phase period selection |

| Offset: 0x0100 |            |             | Register Name: TVE_100_REG                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
|                |            |             | <p>These bits select the number of fields or lines after which the color burst phase is reset to its initial value as specified by the ChromaPhase parameter, This parameter is application only for interlaced video.</p> <p>00: 8 field<br/>01: 4 field<br/>10: 2 lines<br/>11: only once</p> |

### 5.3.7.17 0x0104 TV Encoder VSYNC Number Register (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: TVE_104_REG                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                           |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | <p>VSync5</p> <p>Number of equalization pulse selection</p> <p>This bit selects whether the number of equalization pulses is 5 or 6. This parameter is applicable only for interlaced video.</p> <p>0: 5 equalization pulse(default)<br/>1: 6 equalization pulses</p> |

### 5.3.7.18 0x0108 TV Encoder Notch Filter Frequency Register (Default Value: 0x0000\_0002)

| Offset: 0x0108 |            |             | Register Name: TVE_108_REG                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2:0            | R/W        | 0x2         | <p>Notch_Freq</p> <p>Luma notch filter center frequency selection</p> <p>These bits select the luma notch filter (which is a band-reject filter) center frequency. In two of the selections, the filter width affects also the selection of the center frequency.</p> <p>000: 1.1875<br/>001: 1.1406<br/>010: 1.0938. When notch_wide value is B'1' (this selection is proper for CCIR-NTSC), or 1.0000 when notch_wide value is B'0'.</p> |

| Offset: 0x0108 |            |             | Register Name: TVE_108_REG                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                         |
|                |            |             | 011: 0.9922. This selection is proper for NTSC with square pixels.<br>100: 0.9531. This selection is proper for PAL with square pixel.<br>101: 0.8359 when notch_wide value is B'1' (this selection is proper for CCIR-PAL), or 0.7734 when notch_wide value is B'0'.<br>110: 0.7813<br>111: 0.7188 |

### 5.3.7.19 0x010C TV Encoder Cb/Cr Level/Gain Register (Default Value: 0x0000\_004F)

| Offset: 0x010C |            |             | Register Name: TVE_10C_REG                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                  |
| 15:8           | R/W        | 0x0         | <b>Cr_Burst_Level</b><br>Specify the amplitude of the Cr burst. 8 bit 2's complement integer. Allowed range is from (-127) to 127. |
| 7:0            | R/W        | 0x4f        | <b>Cb_Burst_Level</b><br>Specify the amplitude of the Cb burst. 8 bit 2's complement integer. Allowed range is from (-127) to 127. |

### 5.3.7.20 0x0110 TV Encoder Tint and Color Burst Phase Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: TVE_110_REG                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                               |
| 23:16          | R/W        | 0x0         | <b>Tint</b><br>Specify the tint adjustment of the chroma signal for CVBS and Y/C outputs. The adjustment is effected by setting the sub-carrier phase to the value of this parameter. 8.8 bit unsigned fraction. Units are cycles of the color burst frequency. |
| 15:8           | /          | /           | /                                                                                                                                                                                                                                                               |
| 7:0            | R/W        | 0x0         | <b>Chroma_Phase</b>                                                                                                                                                                                                                                             |

| Offset: 0x0110 |            |             | Register Name: TVE_110_REG                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>Specify the color burst initial phase (ChromaPhase). 8.8 bit unsigned fraction. Units are cycles of the color burst frequency.</p> <p>The color burst is set to this phase at the first HSYNC and then reset to the same value at further HSyncs as specified by the CPhaseRset bits of the EncConfig5 parameter (see above)</p> |

### 5.3.7.21 0x0114 TV Encoder Burst Width Register (Default Value: 0x0016\_447E)

| Offset: 0x0114 |            |             | Register Name: TVE_114_REG                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                          |
| 31:24          | R/W        | 0x0         | <p>Back_Porch</p> <p>Breezeway like in HD mode VSync</p> <p>For 720p mode, the value is 220</p> <p>For 2080i/p mode, the value is 88 (default)</p>                                                                                                                                                                                                   |
| 23             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                    |
| 22:16          | R/W        | 0x16        | <p>Breezeway</p> <p>Must be even</p> <p>Specify the width of the breezeway in encoder clock cycles. 5 bit unsigned integer. Allowed range is 0 to 31.</p> <p>For 1080i mode, the value is 44.</p> <p>For 1080p mode, the value is 44.</p> <p>For 720p mode, the value is 40.</p>                                                                     |
| 15             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                    |
| 14:8           | R/W        | 0x44        | <p>Burst_Width</p> <p>Specify the width of the color frequency burst in encoder clock cycles. 7 bit unsigned integer. Allowed range is 0 to 127.</p> <p>In hd mode, it is ignored.</p>                                                                                                                                                               |
| 7:0            | R/W        | 0x7e        | <p>HSync_Width</p> <p>Specify the width of the horizontal sync pulse in encoder clock cycles. Min value is 16. Max value is (FrontPorch + ActiveLine - BackPorch). Default value is 126. The sum of HSyncSize and BackPorch is restricted to be divisible by 4.</p> <p>For 720p mode, the value is 40.</p> <p>For 1080i/p mode, the value is 44.</p> |

### 5.3.7.22 0x0118 TV Encoder Cb/Cr Gain Register (Default Value: 0x0000\_A0A0)

| Offset: 0x0118 |            |             | Register Name: TVE_118_REG                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:16          | /          | /           | /                                                              |
| 15:8           | R/W        | 0xa0        | Cr_Gain<br>Specify the Cr color gain. 8-bit unsigned fraction. |
| 7:0            | R/W        | 0xa0        | Cb_Gain<br>Specify the Cb color gain. 8-bit unsigned fraction. |

### 5.3.7.23 0x011C TV Encoder Sync and VBI Level Register (Default Value: 0x0010\_00F0)

| Offset: 0x011C |            |             | Register Name: TVE_11C_REG                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:26          | /          | /           | /                                                                                                                                                             |
| 25:16          | R/W        | 0x10        | Sync_Level<br>Specify the sync pulse level setting. 8-bit unsigned integer. Allowed range is from 0 to ABlankLevel-1 or VBlankLevel-1 (whichever is smaller). |
| 15:10          | /          | /           | /                                                                                                                                                             |
| 9:0            | R/W        | 0xf0        | VBlank_Level<br>Specify the blank level setting for non active lines. 10-bit unsigned integer. Allow range is from 0 to 1023.                                 |

### 5.3.7.24 0x0120 TV Encoder White Level Register (Default Value: 0x01E8\_0320)

| Offset: 0x0120 |            |             | Register Name: TVE_120_REG                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:26          | /          | /           | /                                                                                                                                                                 |
| 25:16          | R/W        | 0x1e8       | HD_Sync_Breezeway_Level<br>Specify the breezeway level setting. 10-bit unsigned integer. Allowed range is from 0 to 1023.                                         |
| 15:10          | /          | /           | /                                                                                                                                                                 |
| 9:0            | R/W        | 0x320       | White_Level<br>Specify the white level setting. 10-bit unsigned integer. Allowed range is from black_level+1 or vbi_blank_level+1 (whichever is greater) to 1023. |

### 5.3.7.25 0x0124 TV Encoder Video Active Line Register (Default Value: 0x0000\_05A0)

| Offset: 0x0124 |            |             | Register Name: TVE_124_REG                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:12          | /          | /           | /                                                                                                                                                   |
| 11:0           | R/W        | 0x5A0       | Active_Line<br>Specify the width of the video line in encoder clock cycles. 12-bit unsigned multiple of 4 integer. Allowed range is from 0 to 4092. |

### 5.3.7.26 0x0128 TV Encoder Video Chroma BW and CompGain Register (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: TVE_128_REG                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                       |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                 |
| 17:16          | R/W        | 0x0         | Chroma_BW<br>Chroma filter bandwidth selection<br>This bit specifies whether the bandwidth of the chroma filter is:<br>00: Narrow width 0.6 MHz<br>01: Wide width 1.2 MHz<br>10: Extra width 1.8 MHz<br>11: Ultra width 2.5 MHz                   |
| 15:2           | /          | /           | Comp_Ch_Gain<br>Chroma gain selection for the composite video signal.<br>These bits specify the gain of the chroma signal for composing with the luma signal to generate the composite video signal:<br>00: 100%<br>01: 25%<br>10: 50%<br>11: 75% |
| 1:0            | R/W        | 0x0         |                                                                                                                                                                                                                                                   |

### 5.3.7.27 0x012C TV Encoder Register (Default Value: 0x0000\_0101)

| Offset: 0x012C |            |             | Register Name: TVE_12C_REG                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 8              | R/W        | 0x1         | <p>Notch_Width<br/>Luma notch filter width selection<br/>This bit selects the luma notch filter (which is a band-reject filter) width.<br/>0: Narrow<br/>1: Wide</p>                                                                                                                    |
| 7:1            | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 0              | R/W        | 0x1         | <p>Comp_YUV_EN<br/>This bit selects if the components video output are the RGB components or the YUV components.<br/>0: The three component outputs are the RGB components.<br/>1: The three component outputs are the YUV components, (i.e. the color conversion unit is bypassed)</p> |

### 5.3.7.28 0x0130 TV Encoder Re-sync Parameters Register (Default Value: 0x0010\_0001)

| Offset: 0x0130 |            |             | Register Name: TVE_130_REG                                      |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31             | R/W        | 0x0         | <p>Re_Sync_Field<br/>Re-sync field</p>                          |
| 30             | R/W        | 0x0         | <p>Re_Sync_Dis<br/>0: Re-Sync Enable<br/>1: Re-Sync Disable</p> |
| 29:27          | /          | /           | /                                                               |
| 26:16          | R/W        | 0x10        | <p>Re_Sync_Line_Num<br/>Re-sync line number from TCON</p>       |
| 15:11          | /          | /           | /                                                               |
| 10:0           | R/W        | 0x1         | <p>Re_Sync_Pixel_Num<br/>Re-sync line pixel from TCON</p>       |

### 5.3.7.29 0x0134 TV Encoder Slave Parameter Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: TVE_134_REG                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 8              | R/W        | 0x0         | <p>Slave_Thresh<br/>Horizontal line adjustment threshold selection<br/>This bit selects whether the number of lines after which the Video Encoder starts the horizontal line length adjustment is slave mode is 0 or 30.<br/>0: Number of lines is 0<br/>1: Number of lines is 30</p> |
| 7:1            | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | <p>Slave_Mode<br/>Slave mode selection<br/>This bit selects whether the Video Encoder is sync slave, partial slave or sync master. It should be set to B'0'.<br/>0: The Video Encoder is not a full sync slave (i.e. it is a partial sync slave or a sync master)<br/>1: Reserved</p> |

### 5.3.7.30 0x0138 TV Encoder Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0138 |            |             | Register Name: TVE_138_REG                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | <p>Invert_Top<br/>Field parity input signal (top_field) polarity selection.<br/>This bit selects whether the top field is indicated by a high level of the field parity signal or by the low level. The bit is applicable both when the Video Encoder is the sync master and when the Video Encoder is the sync slave.<br/>0: Top field is indicated by low level<br/>1: Top field is indicated by high level</p> |
| 7:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | R/W        | 0x0         | UV_Order<br>This bit selects if the sample order at the chroma input to the Video Encoder is Cb first (i.e. Cb 0 Cr 0 Cb 1 Cr 1) or Cr first (i.e. Cr 0 Cb 0 Cr 1 Cb 1).                                                                                                                                                                                                                                          |

| Offset: 0x0138 |            |             | Register Name: TVE_138_REG                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
|                |            |             | 0: The chroma sample input order is Cb first<br>1: The chroma sample input order is Cr first |

### 5.3.7.31 0x013C TV Encoder Configuration Register (Default Value: 0x0000\_0001)

| Offset: 0x013C |            |             | Register Name: TVE_13C_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 26:24          | R/W        | 0x0         | RGB_Sync<br>R, G and B signals sync embedding selection.<br>These bits specify whether the sync signal is added to each of the R, G and B components (b'1') or not (b'0'). The bit[26] specify if the R signal has embedded syncs, the bit[25] specify if the G signal has embedded syncs and the bit[24] specify if the B signal has embedded syncs. When comp_yuv is equal to b'1', these bits are N.A. and should be set to b'000'. When the value is different from b'000', RGB_Setup should be set to b'1'. |
| 23:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16             | R/W        | 0x0         | RGB_Setup<br>“Set-up” enable for RGB outputs.<br>This bit specifies if the “set-up” implied value (black_level – blank_level) specified for the CVBS signal is used also for the RGB signals.<br>0: The “set-up” is not used, or i.e. comp_yuv is equal to b'1'.<br>1: The implied “set-up” is used for the RGB signals                                                                                                                                                                                          |
| 15:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0              | R/W        | 0x1         | Bypass_YClamp<br>Y input clamping selection<br>This bit selects whether the Video Encoder Y input is clamped to 64 to 940 or not. When not clamped the expected range is 0 to 1023. The U and V inputs are always clamped to the range 64 to 960.<br>0: The Video Encoder Y input is clamped<br>1: The Video Encoder Y input is not clamped                                                                                                                                                                      |

### 5.3.7.32 0x0380 TV Encoder Low Pass Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0380 |            |             | Register Name: TVE_380_REG                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:14          | /          | /           | /                                                                        |
| 13:10          | R/W        | 0x0         | User_deflicker_coef<br>up: coef/32<br>Center: 1-coef/16<br>Down: coef/32 |
| 9              | R/W        | 0x0         | Fix_coef_deflicker<br>0: Auto deflicker<br>1: User deflicker             |
| 8              | R/W        | 0x0         | Enable_deflicker<br>0: Disable deflicker<br>1: Enable deflicker          |
| 7:1            | /          | /           | /                                                                        |
| 0              | R/W        | 0x0         | EN<br>LP function enable<br>0: Disable<br>1: Enable                      |

### 5.3.7.33 0x0384 TV Encoder Low Pass Filter Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0384 |            |             | Register Name: TVE_384_REG                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:22          | /          | /           | /                                                                                               |
| 21:16          | R/W        | 0x0         | HP_RATIO<br>Default high-pass filter ratio<br>In two complement, the range is from -31 to 31.   |
| 15:14          | /          | /           | /                                                                                               |
| 13:8           | R/W        | 0x0         | BPO_RATIO<br>Default band-pass filter0 ratio<br>In two complement, the range is from -31 to 31. |
| 7:6            | /          | /           | /                                                                                               |
| 5:0            | R/W        | 0x0         | BP1_RATIO<br>Default band-pass filter1 ratio<br>In two complement, the range is from -31 to 31. |

### 5.3.7.34 0x0388 TV Encoder Low Pass Gain Register (Default Value: 0x0000\_0000)

| Offset: 0x0388 |            |             | Register Name: TVE_388_REG    |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:8           | /          | /           | /                             |
| 7:0            | R/W        | 0x0         | GAIN<br>Peaking gain setting. |

### 5.3.7.35 0x038C TV Encoder Low Pass Gain Control Register (Default Value: 0x0000\_0000)

| Offset: 0x038C |            |             | Register Name: TVE_38C_REG                    |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:24          | /          | /           | /                                             |
| 23:16          | R/W        | 0x0         | DIF_UP<br>Gain control: limitation threshold. |
| 15:8           | /          | /           | /                                             |
| 4:0            | R/W        | 0x0         | BETA<br>Gain control: large gain limitation.  |

### 5.3.7.36 0x0390 TV Encoder Low Pass Shoot Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0390 |            |             | Register Name: TVE_390_REG           |
|----------------|------------|-------------|--------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                          |
| 31:6           | /          | /           | /                                    |
| 5:0            | R/W        | 0x0         | NEG_GAIN<br>Undershoot gain control. |

### 5.3.7.37 0x0394 TV Encoder Low Pass Coring Register (Default Value: 0x0000\_0000)

| Offset: 0x0394 |            |             | Register Name: TVE_394_REG  |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R/W        | 0x0         | CORTHR<br>Coring threshold. |

### 5.3.7.38 0x03A0 TV Encoder Noise Reduction Register (Default Value: 0x0000\_0000)

| Offset: 0x03A0 |            |             | Register Name: TVE_3A0_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:24          | /          | /           | /                          |
| 23:16          | R/W        | 0x0         | T_Value                    |
| 15:1           | /          | /           | /                          |
| 0              | R/W        | 0x0         | EN                         |

## 5.4 MIPI DSI

### 5.4.1 Overview

The Display Serial Interface is a high-speed interface between a host processor and peripheral devices that adhere to MIPI Alliance specifications for mobile device interfaces. This DSI module is composed of a DSI controller which is compliance with MIPI DSI specification V1.01 and a D-PHY module which is compliance with MIPI DPHY specification V1.00.

The MIPI DSI includes the following features:

- Compliance with MIPI DSI v1.01
- Up to 4 lanes
- Supports 1280 x 720@60fps (for T113-S2) and 1920 x 1200@60fps (for others)
- Supports non-burst mode with sync pulse/sync event and burst mode
- Supports pixel format: RGB888, RGB666, RGB666 loosely packed and RGB565
- Supports continuous lane clock mode and non-continuous lane clock mode
- Compliance with MIPI DCS v1.01, bidirectional communication in LP through data lane 0
- Supports bidirectional communication of all generic commands in LP through data lane 0
- Supports low power data transmission
- Supports ULPS and Escape modes
- Hardware checksum capabilities

# Contents

|       |                                     |     |
|-------|-------------------------------------|-----|
| 6     | Video Input Interfaces.....         | 530 |
| 6.1   | CSIC .....                          | 530 |
| 6.1.1 | Overview .....                      | 530 |
| 6.1.2 | Block Diagram .....                 | 530 |
| 6.1.3 | Functional Description .....        | 531 |
| 6.1.4 | Register List.....                  | 533 |
| 6.1.5 | CCU Register Description .....      | 537 |
| 6.1.6 | CSIC Top Register Description ..... | 538 |
| 6.1.7 | Parser Register Description.....    | 543 |
| 6.1.8 | CSIC DMA Register Description.....  | 564 |
| 6.2   | TV Decoder.....                     | 579 |
| 6.2.1 | Overview .....                      | 579 |
| 6.2.2 | Block Diagram .....                 | 579 |
| 6.2.3 | Functional Description .....        | 579 |
| 6.2.4 | Register List.....                  | 580 |
| 6.2.5 | Register Description .....          | 582 |

## Figures

|                                     |     |
|-------------------------------------|-----|
| Figure 6-1 CSIC Block Diagram ..... | 530 |
| Figure 6-2 RAW-10 Format .....      | 531 |
| Figure 6-3 RAW-12 Format .....      | 531 |
| Figure 6-4 YUV-10 Format.....       | 532 |
| Figure 6-5 RGB888 Format.....       | 532 |
| Figure 6-6 PRGB888 Format.....      | 532 |
| Figure 6-7 RGB565 Format.....       | 532 |
| Figure 6-8 TVD Block Diagram.....   | 579 |

## Tables

|                                        |     |
|----------------------------------------|-----|
| Table 6-1 CSIC External Signals .....  | 531 |
| Table 6-2 CSIC FIFO Distribution ..... | 531 |
| Table 6-3 TVD External Signals.....    | 580 |



# 6 Video Input Interfaces

## 6.1 CSIC

### 6.1.1 Overview

The CMOS Sensor Interface Controller (CSIC) is an image or video data receiver, which can receive image or video data via camera interface and store the data in memory directly.

The CSIC includes the following features:

- Supports 8-bit digital camera interface
- Supports BT656 Interface
  - Supports time-multiplexed format
  - Supports dual data rate sample mode with pixel clock up to 148.5 MHz
- Supports BT601 Interface
- Supports crop function
- Supports frame rate down
- Supports 2 DMA for 2 video stream storage
  - Supports de-interlacing for interlace video input
  - Supports conversion from YUV422 to YUV420, YUV422 to YUV400, YUV420 to YUV400
  - Supports horizontal and vertical flip

### 6.1.2 Block Diagram

Figure 6-1 shows block diagram of the CSIC.

**Figure 6-1 CSIC Block Diagram**



### **6.1.3 Functional Description**

### 6.1.3.1 External Signals

**Table 6-1 CSIC External Signals**

| Port Name    | Description                  | Type |
|--------------|------------------------------|------|
| NCSI0-PCLK   | Parallel CSI Pixel Clock     | I    |
| NCSI0-MCLK   | Parallel CSI Master Clock    | O    |
| NCSI0-HSYNC  | Parallel CSI Horizontal Sync | I    |
| NCSI0-VSYNC  | Parallel CSI Vertical Sync   | I    |
| NCSI0-D[7:0] | Parallel CSI Data Bit        | I    |
| NCSI0-FIELD  | Parallel CSI Field Index     | I    |

### **6.1.3.2 CSIC FIFO Distribution**

**Table 6-2 CSIC FIFO Distribution**

| Interface     | MIPI Interface |             |                 |
|---------------|----------------|-------------|-----------------|
| Input format  | YUV422         |             | Raw             |
| Output format | Planar         | UV combined | Raw/RGB/PRGB    |
| CHO_FIFO0     | Y              | Y           | All pixels data |
| CHO_FIFO1     | Cb (U)         | CbCr (UV)   | -               |
| CHO_FIFO2     | Cr (V)         | -           | -               |

### **6.1.3.3 Pixel Format Arrangement**

## Figure 6-2 RAW-10 Format



## Figure 6-3 RAW-12 Format



**Figure 6-4 YUV-10 Format**

|             |            |              |            |
|-------------|------------|--------------|------------|
| Dummy1[5:0] | Y1[9:0]    | Dummy 0[5:0] | Y 0[9:0]   |
| MSB         |            |              | LSB        |
| Dummy1[5:0] | V/U 0[9:0] | Dummy 0[5:0] | U/V 0[9:0] |
| MSB         |            |              | LSB        |

**Figure 6-5 RGB888 Format**

|         |         |         |         |
|---------|---------|---------|---------|
| B1[7:0] | R0[7:0] | G0[7:0] | B0[7:0] |
| G2[7:0] | B2[7:0] | R1[7:0] | G1[7:0] |
| R3[7:0] | G3[7:0] | B3[7:0] | R2[7:0] |

**Figure 6-6 PRGB888 Format**

|          |         |         |         |
|----------|---------|---------|---------|
| PAD[7:0] | R0[7:0] | G0[7:0] | B0[7:0] |
| MSB      |         |         | LSB     |

**Figure 6-7 RGB565 Format**

|         |         |         |         |         |         |
|---------|---------|---------|---------|---------|---------|
| R1[4:0] | G1[5:0] | B1[4:0] | R0[4:0] | G0[5:0] | B0[4:0] |
| MSB     |         |         |         |         | LSB     |

#### 6.1.3.4 Offset Definition

Offset in horizontal and vertical can be added when receiving image. Unit is pixel.

For YUV422 format, pixel unit is a YU/YV combination.

For YUV420 format, pixel unit is a YU/YV combination in YC line, and only a Y in Y line.

For Bayer and RAW format, pixel unit is a R/G/B single component.

For RGB565, pixel unit is 2 bytes of RGB565 package.

For RGB888, pixel unit is 3 bytes of RGB combination.

### 6.1.3.5 Flip Definition

Both horizontal and vertical flip are supported at the same time. This function is implemented in the process of each FIFO writing data to memory, only flipping the data of separate FIFO, not changing component to FIFO distribution.

If horizontal flip is enabled, one or more pixels will be took as a unit:

For YUV format, a unit of  $Y_0U_0Y_1V_1$  will parser and flip the Y component in one channel, and UV will be treated as a whole. In planar output mode, U and V will be flipped separately. In UV combined output mode, UV will be flipped as a whole. So, a sequence of  $Y_1U_0Y_0V_1$  will be.

For Bayer\_raw format, situation is much like. A GR/BG sequence will be changed to BG/RG. A unit of square has four pixels.

For RGB565/RGB888, one unit of two/three bytes of component will be flipped with original sequence.

### 6.1.4 Register List

| Module Name  | Base Address |
|--------------|--------------|
| CSIC_CCU     | 0x05800000   |
| CSIC_TOP     | 0x05800800   |
| CSIC_PARSERO | 0x05801000   |
| CSIC_DMA0    | 0x05809000   |
| CSIC_DMA1    | 0x05809200   |

CCU register list:

| Register Name         | Offset | Register Description             |
|-----------------------|--------|----------------------------------|
| CCU_CLK_MODE_REG      | 0x0000 | CCU Clock Mode Register          |
| CCU_PARSER_CLK_EN_REG | 0x0004 | CCU Parser Clock Enable Register |
| CCU_POST0_CLK_EN_REG  | 0x000C | CCU Post0 Clock Enable Register  |

CSIC TOP register list:

| Register Name           | Offset | Register Description                     |
|-------------------------|--------|------------------------------------------|
| CSIC_TOP_EN_REG         | 0x0000 | CSIC TOP Enable Register                 |
| CSIC_PTN_GEN_EN_REG     | 0x0004 | CSIC Pattern Generation Enable Register  |
| CSIC_PTN_CTRL_REG       | 0x0008 | CSIC Pattern Control Register            |
| CSIC_PTN_LEN_REG        | 0x0020 | CSIC Pattern Generation Length Register  |
| CSIC_PTN_ADDR_REG       | 0x0024 | CSIC Pattern Generation Address Register |
| CSIC_PTN_ISP_SIZE_REG   | 0x0028 | CSIC Pattern ISP Size Register           |
| CSIC_DMA0_INPUT_SEL_REG | 0x00A0 | CSIC DMA0 Input Select Register          |
| CSIC_DMA1_INPUT_SEL_REG | 0x00A4 | CSIC DMA1 Input Select Register          |
| CSIC_BIST_CS_REG        | 0x00DC | CSIC BIST CS Register                    |
| CSIC_BIST_CONTROL_REG   | 0x00E0 | CSIC BIST Control Register               |
| CSIC_BIST_START_REG     | 0x00E4 | CSIC BIST Start Register                 |
| CSIC_BIST_END_REG       | 0x00E8 | CSIC BIST End Register                   |
| CSIC_BIST_DATA_MASK_REG | 0x00EC | CSIC BIST Data Mask Register             |
| CSIC_MBUS_REQ_MAX_REG   | 0x00F0 | CSIC MBUS REQ MAX Register               |
| CSIC_MULF_MOD_REG       | 0x0100 | CSIC Multi-Frame Mode Register           |
| CSIC_MULF_INT_REG       | 0x0104 | CSIC Multi-Frame Interrupt Register      |

PARSER0 register list:

| Register Name                     | Offset | Register Description                                  |
|-----------------------------------|--------|-------------------------------------------------------|
| PRS_EN_REG                        | 0x0000 | Parser Enable Register                                |
| PRS_NCSIC_IF_CFG_REG              | 0x0004 | Parser NCSIC Interface Configuration Register         |
| PRS_CAP_REG                       | 0x000C | Parser Capture Register                               |
| CSIC_PRS_SIGNAL_STA_REG           | 0x0010 | CSIC Parser Signal Status Register                    |
| CSIC_PRS_NCSIC_BT656_HEAD_CFG_REG | 0x0014 | CSIC Parser NCSIC BT656 Header Configuration Register |
| PRS_C0_INFMT_REG                  | 0x0024 | Parser Channel_0 Input Format Register                |
| PRS_C0_OUTPUT_HSIZE_REG           | 0x0028 | Parser Channel_0 Output Horizontal Size Register      |
| PRS_C0_OUTPUT_VSIZE_REG           | 0x002C | Parser Channel_0 Output Vertical Size Register        |
| PRS_C0_INPUT_PARAO_REG            | 0x0030 | Parser Channel_0 Input Parameter0 Register            |
| PRS_C0_INPUT_PARA1_REG            | 0x0034 | Parser Channel_0 Input Parameter1 Register            |
| PRS_C0_INPUT_PARA2_REG            | 0x0038 | Parser Channel_0 Input Parameter2 Register            |
| PRS_C0_INPUT_PARA3_REG            | 0x003C | Parser Channel_0 Input Parameter3 Register            |
| PRS_C0_INT_EN_REG                 | 0x0040 | Parser Channel_0 Interrupt Enable Register            |
| PRS_C0_INT_STA_REG                | 0x0044 | Parser Channel_0 Interrupt Status Register            |
| PRS_CHO_LINE_TIME_REG             | 0x0048 | Parser Channel_0 Line Time Register                   |
| PRS_C1_INFMT_REG                  | 0x0124 | Parser Channel_1 Input Format Register                |
| PRS_C1_OUTPUT_HSIZE_REG           | 0x0128 | Parser Channel_1 Output Horizontal Size Register      |
| PRS_C1_OUTPUT_VSIZE_REG           | 0x012C | Parser Channel_1 Output Vertical Size Register        |

| Register Name                         | Offset | Register Description                               |
|---------------------------------------|--------|----------------------------------------------------|
| PRS_C1_INPUT_PARA0_REG                | 0x0130 | Parser Channel_1 Input Parameter0 Register         |
| PRS_C1_INPUT_PARA1_REG                | 0x0134 | Parser Channel_1 Input Parameter1 Register         |
| PRS_C1_INPUT_PARA2_REG                | 0x0138 | Parser Channel_1 Input Parameter2 Register         |
| PRS_C1_INPUT_PARA3_REG                | 0x013C | Parser Channel_1 Input Parameter3 Register         |
| PRS_C1_INT_EN_REG                     | 0x0140 | Parser Channel_1 Interrupt Enable Register         |
| PRS_C1_INT_STA_REG                    | 0x0144 | Parser Channel_1 Interrupt Status Register         |
| PRS_CH1_LINE_TIME_REG                 | 0x0148 | Parser Channel_1 Line Time Register                |
| PRS_C2_INFMT_REG                      | 0x0224 | Parser Channel_2 Input Format Register             |
| PRS_C2_OUTPUT_HSIZE_REG               | 0x0228 | Parser Channel_2 Output Horizontal Size Register   |
| PRS_C2_OUTPUT_VSIZE_REG               | 0x022C | Parser Channel_2 Output Vertical Size Register     |
| PRS_C2_INPUT_PARA0_REG                | 0x0230 | Parser Channel_2 Input Parameter0 Register         |
| PRS_C2_INPUT_PARA1_REG                | 0x0234 | Parser Channel_2 Input Parameter1 Register         |
| PRS_C2_INPUT_PARA2_REG                | 0x0238 | Parser Channel_2 Input Parameter2 Register         |
| PRS_C2_INPUT_PARA3_REG                | 0x023C | Parser Channel_2 Input Parameter3 Register         |
| PRS_C2_INT_EN_REG                     | 0x0240 | Parser Channel_2 Interrupt Enable Register         |
| PRS_C2_INT_STA_REG                    | 0x0244 | Parser Channel_2 Interrupt Status Register         |
| PRS_CH2_LINE_TIME_REG                 | 0x0248 | Parser Channel_2 Line Time Register                |
| PRS_C3_INFMT_REG                      | 0x0324 | Parser Channel_3 Input Format Register             |
| PRS_C3_OUTPUT_HSIZE_REG               | 0x0328 | Parser Channel_3 Output Horizontal Size Register   |
| PRS_C3_OUTPUT_VSIZE_REG               | 0x032C | Parser Channel_3 Output Vertical Size Register     |
| PRS_C3_INPUT_PARA0_REG                | 0x0330 | Parser Channel_3 Input Parameter0 Register         |
| PRS_C3_INPUT_PARA1_REG                | 0x0334 | Parser Channel_3 Input Parameter1 Register         |
| PRS_C3_INPUT_PARA2_REG                | 0x0338 | Parser Channel_3 Input Parameter2 Register         |
| PRS_C3_INPUT_PARA3_REG                | 0x033C | Parser Channel_3 Input Parameter3 Register         |
| PRS_C3_INT_EN_REG                     | 0x0340 | Parser Channel_3 Interrupt Enable Register         |
| PRS_C3_INT_STA_REG                    | 0x0344 | Parser Channel_3 Interrupt Status Register         |
| PRS_CH3_LINE_TIME_REG                 | 0x0348 | Parser Channel_3 Line Time Register                |
| CSIC_PRS_NCSIC_RX_SIGNAL0_DLY_ADJ_REG | 0x0500 | CSIC Parser NCSIC RX Signal0 Delay Adjust Register |
| CSIC_PRS_NCSIC_RX_SIGNAL5_DLY_ADJ_REG | 0x0514 | CSIC Parser NCSIC RX Signal5 Delay Adjust Register |
| CSIC_PRS_NCSIC_RX_SIGNAL6_DLY_ADJ_REG | 0x0518 | CSIC Parser NCSIC RX Signal6 Delay Adjust Register |

DMA0/1 register list:

| Register Name      | Offset | Register Description              |
|--------------------|--------|-----------------------------------|
| CSIC_DMA_EN_REG    | 0x0000 | CSIC DMA Enable Register          |
| CSIC_DMA_CFG_REG   | 0x0004 | CSIC DMA Configuration Register   |
| CSIC_DMA_HSIZE_REG | 0x0010 | CSIC DMA Horizontal Size Register |
| CSIC_DMA_VSIZE_REG | 0x0014 | CSIC DMA Vertical Size Register   |

| Register Name                      | Offset | Register Description                                     |
|------------------------------------|--------|----------------------------------------------------------|
| CSIC_DMA_F0_BUFA_REG               | 0x0020 | CSIC DMA FIFO 0 Output Buffer-A Address Register         |
| CSIC_DMA_F0_BUFA_RESULT_REG        | 0x0024 | CSIC DMA FIFO 0 Output Buffer-A Address Result Register  |
| CSIC_DMA_F1_BUFA_REG               | 0x0028 | CSIC DMA FIFO 1 Output Buffer-A Address Register         |
| CSIC_DMA_F1_BUFA_RESULT_REG        | 0x002C | CSIC DMA FIFO 1 Output Buffer-A Address Result Register  |
| CSIC_DMA_F2_BUFA_REG               | 0x0030 | CSIC DMA FIFO 2 Output Buffer-A Address Register         |
| CSIC_DMA_F1_BUFA_RESULT_REG        | 0x0034 | CSIC DMA FIFO 2 Output Buffer-A Address Result Register  |
| CSIC_DMA_BUF_LEN_REG               | 0x0038 | CSIC DMA Buffer Length Register                          |
| CSIC_DMA_FLIP_SIZE_REG             | 0x003C | CSIC DMA Flip Size Register                              |
| CSIC_DMA_VI_TO_TH0_REG             | 0x0040 | CSIC DMA Video Input Timeout Threshold0 Register         |
| CSIC_DMA_VI_TO_TH1_REG             | 0x0044 | CSIC DMA Video Input Timeout Threshold1 Register         |
| CSIC_DMA_VI_TO_CNT_VAL_REG         | 0x0048 | CSIC DMA Video Input Timeout Counter Value Register      |
| CSIC_DMA_CAP_STA_REG               | 0x004C | CSIC DMA Capture Status Register                         |
| CSIC_DMA_INT_EN_REG                | 0x0050 | CSIC DMA Interrupt Enable Register                       |
| CSIC_DMA_INT_STA_REG               | 0x0054 | CSIC DMA Interrupt Status Register                       |
| CSIC_DMA_LINE_CNT_REG              | 0x0058 | CSIC DMA LINE Counter Register                           |
| CSIC_DMA_FRM_CNT_REG               | 0x005C | CSIC DMA Frame Counter Register                          |
| CSIC_DMA_FRM_CLK_CNT_REG           | 0x0060 | CSIC DMA Frame Clock Counter Register                    |
| CSIC_DMA_ACC_ITNL_CLK_CNT_REG      | 0x0064 | CSIC DMA Accumulated And Internal Clock Counter Register |
| CSIC_DMA_FIFO_STAT_REG             | 0x0068 | CSIC DMA FIFO Statistic Register                         |
| CSIC_DMA_FIFO_THRS_REG             | 0x006C | CSIC DMA FIFO Threshold Register                         |
| CSIC_DMA_PCLK_STAT_REG             | 0x0070 | CSIC DMA PCLK Statistic Register                         |
| CSIC_DMA_BUF_ADDR_FIFO0_ENTR_Y_REG | 0x0080 | CSIC DMA BUF Address FIFO0 Entry Register                |
| CSIC_DMA_BUF_ADDR_FIFO1_ENTR_Y_REG | 0x0084 | CSIC DMA BUF Address FIFO1 Entry Register                |
| CSIC_DMA_BUF_ADDR_FIFO2_ENTR_Y_REG | 0x0088 | CSIC DMA BUF Address FIFO2 Entry Register                |
| CSIC_DMA_BUF_TH_REG                | 0x008C | CSIC DMA BUF Threshold Register                          |
| CSIC_DMA_BUF_ADDR_FIFO_CON_REG     | 0x0090 | CSIC DMA BUF Address FIFO Content Register               |
| CSIC_DMA_STORED_FRM_CNT_REG        | 0x0094 | CSIC DMA Stored Frame Counter Register                   |
| CSIC_FEATURE_REG                   | 0x01F4 | CSIC DMA Feature List Register                           |

### 6.1.5 CCU Register Description

#### 6.1.5.1 0x0000 CCU Clock Mode Register(Default Value:0x8000\_0000)

| Offset: 0x0000 |            |             | Register Name: CCU_CLK_MODE_REG                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31             | R/W        | 0x1         | CCU_CLK_GATING_DISABLE<br>0: CCU Clock Gating Registers(0x0004~0x0010) effect<br>1: CCU Clock Gating Registers(0x0004~0x0010) not effect |
| 30:0           | /          | /           | /                                                                                                                                        |

#### 6.1.5.2 0x0004 CCU Parser Clock Enable Register(Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CCU_PARSER_CLK_EN_REG                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:1           | /          | /           | /                                                                                      |
| 0              | R/W        | 0x0         | MCSI_PARSER0_CLK_ENABLE<br>0: CSI Parser0 clock disable<br>1: CSI Parser0 clock enable |

#### 6.1.5.3 0x000C CCU Post0 Clock Enable Register(Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CCU_POST0_CLK_EN_REG                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:17          | /          | /           | /                                                                                                  |
| 16             | R/W        | 0x0         | MCSI_POST0_CLK_ENABLE<br>0: POST0 clock disable<br>1: POST0 clock enable                           |
| 15:2           | /          | /           | /                                                                                                  |
| 1              | R/W        | 0x0         | MCSI_BK1_CLK_ENABLE<br>0: BK1 clock disable<br>1: BK1 clock enable,when MCSI_POST0_CLK_ENABLE is 1 |
| 0              | R/W        | 0x0         | MCSI_BK0_CLK_ENABLE<br>0: BK0 clock disable<br>1: BK0 clock enable,when MCSI_POST0_CLK_ENABLE is 1 |

### 6.1.6 CSIC Top Register Description

#### 6.1.6.1 0x0000 CSIC TOP Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CSIC_TOP_EN_REG                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:3           | /          | /           | /                                                                                |
| 2              | R/W        | 0x0         | BIST_MODE_EN<br>0: Closed<br>1: EN BIST TEST                                     |
| 1              | /          | /           | /                                                                                |
| 0              | R/W        | 0x0         | CSIC_TOP_EN<br>0: Reset and disable the CSIC module<br>1: Enable the CSIC module |

#### 6.1.6.2 0x0004 CSIC Pattern Generation Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CSIC_PTN_GEN_EN_REG                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                           |
| 23:16          | R/W        | 0x0         | PTN_CYCLE<br>Pattern generating cycle counter.<br>The pattern in dram will be generated in cycles of PTN_CYCLE+1.                                                                                                                                           |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                           |
| 4              | R/WAC      | 0x0         | PTN_START<br>CSIC Pattern Generating Start<br>0: Finish<br>1: Start<br>Software writes this bit to "1" to start pattern generating from DRAM. When finished, the hardware will clear this bit to "0" automatically. Generating cycles depends on PTN_CYCLE. |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                           |
| 0              | R/W        | 0x0         | PTN_GEN_EN<br>Pattern Generation Enable                                                                                                                                                                                                                     |

#### 6.1.6.3 0x0008 CSIC Pattern Control Register (Default Value:0x0000\_000F)

| Offset: 0x0008 |            |             | Register Name: CSIC_PTN_CTRL_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:26          | /          | /           | /                                |

| Offset: 0x0008 |            |             | Register Name: CSIC_PTN_CTRL_REG                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 25:24          | R/W        | 0x0         | PTN_PORT_SEL<br>Pattern Generator output port selection<br>10:NCSICO<br>others:reserved                                                                                                                                                                                                                                                                                 |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 21:20          | R/W        | 0x0         | PTN_GEN_DATA_WIDTH<br>00:8-bit<br>01:10-bit<br>10:12-bit<br>11:reserved                                                                                                                                                                                                                                                                                                 |
| 19:16          | R/W        | 0x0         | PTN_MODE<br>Pattern mode selection<br>0000-0011:reserved<br>0100:NCSIC YUV 8 bits width<br>0101:NCSIC YUV 16 bits width<br>0110:reserved<br>0111:reserved<br>1000:BT656 8 bits width<br>1001:BT656 16 bits width<br>1010:reserved<br>1011:reserved<br>1100:BAYER 12 bits for ISPFE<br>1101:UYVY422 12 bits for ISPFE<br>1110:UYVY420 12 bits for ISPFE<br>1111:reserved |
| 15:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 9:8            | R/W        | 0x0         | PTN_GEN_CLK_DIV<br>Packet generator clock divider                                                                                                                                                                                                                                                                                                                       |
| 7:0            | R/W        | 0xF         | PTN_GEN_DLY<br>Clocks delayed before pattern generating start.                                                                                                                                                                                                                                                                                                          |

#### 6.1.6.4 0x0020 CSIC Pattern Generation Length Register (Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CSIC_PTN_LEN_REG                                |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:0           | R/W        | 0x0         | PTN_LEN<br>The pattern length in byte when generating pattern. |

#### 6.1.6.5 0x0024 CSIC Pattern Generation Address Register (Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CSIC_PTN_ADDR_REG                              |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:0           | R/W        | 0x0         | PTN_ADDR<br>The pattern DRAM address when generating pattern. |

#### 6.1.6.6 0x0028 CSIC Pattern ISP Size Register (Default Value:0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CSIC_PTN_ISP_SIZE_REG                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:29          | /          | /           | /                                                                     |
| 28:16          | R/W        | 0x0         | Height<br>Vertical size, only valid for ISP mode pattern generation.  |
| 15:13          | /          | /           | /                                                                     |
| 12:0           | R/W        | 0x0         | Width<br>Horizontal size, only valid for ISP mode pattern generation. |

#### 6.1.6.7 0x00A0 CSIC DMA0 Input Select Register (Default Value:0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: CSIC_DMA0_INPUT_SEL_REG                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 31:4           | /          | /           | /                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | DMA0 Input Select<br>0000: input from ISPO CH0<br>0001: input from ISPO CH1<br>0010: input from ISPO CH2<br>0011: input from ISPO CH3<br>Others: Reserved |

#### 6.1.6.8 0x00A4 CSIC DMA1 Input Select Register (Default Value:0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: CSIC_DMA1_INPUT_SEL_REG                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:4           | /          | /           | /                                                                                                        |
| 3:0            | R/W        | 0x0         | DMA1 Input Select<br>0000: input from ISPO CH0<br>0001: input from ISPO CH1<br>0010: input from ISPO CH2 |

| Offset: 0x00A4 |            |             | Register Name: CSIC_DMA1_INPUT_SEL_REG        |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
|                |            |             | 0011: input from ISPO CH3<br>Others: Reserved |

#### 6.1.6.9 0x00DC CSIC BIST CS Register (Default Value:0x0000\_0000)

| Offset: 0x00DC |            |             | Register Name: CSIC_BIST_CS_REG                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:3           | /          | /           | /                                                                                             |
| 2:0            | R/W        | 0x0         | BIST_CS<br>000: Set when BK0 memory bist<br>001: Set when BK1 memory bist<br>Others: Reserved |

#### 6.1.6.10 0x00E0 CSIC BIST Control Register (Default Value:0x0000\_0200)

| Offset :0x00E0 |            |             | Register Name: CSIC_BIST_CTRL_REG                             |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:16          | /          | /           | /                                                             |
| 15             | R          | 0x0         | BIST_ERR_STA<br>BIST Error Status<br>0: No effect<br>1: Error |
| 14:12          | R          | 0x0         | BIST_ERR_PAT<br>BIST Error Pattern                            |
| 11:10          | R          | 0x0         | BIST_ERR_CYC<br>BIST Error Cycle                              |
| 9              | R          | 0x1         | BIST_STOP<br>BIST STOP<br>0: Running<br>1: Stop               |
| 8              | R          | 0x0         | BIST_BUSY<br>BIST Busy<br>0: Idle<br>1: Busy                  |
| 7:5            | R/W        | 0x0         | BIST_REG_SEL<br>BIST REG select                               |
| 4              | R/W        | 0x0         | BIST_ADDR_Mode_SEL<br>BIST Address Mode Select                |
| 3:1            | R/W        | 0x0         | BIST_WDATA_PAT                                                |

| Offset :0x00E0 |            |             | Register Name: CSIC_BIST_CTRL_REG                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
|                |            |             | BIST Write Data Pattern<br>000: 0x00000000<br>001: 0x55555555<br>010: 0x33333333<br>011: 0xOFOFOFOF<br>100: 0x0OFF0OFF<br>101: 0x0000FFFF<br>others: Reserved |
| 0              | R/W        | 0x0         | BIST_EN<br>BIST Enable<br>A positive will trigger the BIST to start.                                                                                          |

#### 6.1.6.11 0x00E4 CSIC BIST Start Address Register (Default Value:0x0000\_0000)

| Offset :0x00E4 |            |             | Register Name: CSIC_BIST_START_ADDR_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:0           | R/W        | 0x0         | BIST Start Address<br>BIST Start Address. It is 32-bit aligned. |

#### 6.1.6.12 0x00E8 CSIC BIST End Address Register (Default Value:0x0000\_0000)

| Offset :0x00E8 |            |             | Register Name: CSIC_BIST_END_ADDR_REG                       |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:0           | R/W        | 0x0         | BIST END Address<br>BIST END Address. It is 32-bit aligned. |

#### 6.1.6.13 0x00EC CSIC BIST Data Mask Register (Default Value:0x0000\_0000)

| Offset :0x00EC |            |             | Register Name: CSIC_BIST_DATA_MASK_REG                   |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:0           | R/W        | 0x0         | BIST_DATA_MASK<br>BIST Data Mask<br>0: Unmask<br>1: Mask |

#### 6.1.6.14 0x00F0 CSIC MBUS REQ MAX Register (Default Value:0x000F\_0F0F)

| Offset: 0x00F0 |            |             | Register Name: CSIC_MBUS_REQ_MAX_REG                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:5           | /          | /           | /                                                                                                  |
| 4:0            | R/W        | 0x0F        | MCSI_MEM_REQ_MAX<br>Maximum of request commands for the master granted in MCSI_MEM arbiter is N+1. |

#### 6.1.6.15 0x0100 CSIC Multi-Frame Mode Register (Default Value:0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: CSIC_MULF_MOD_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:24          | R          | 0x0         | MULF_STATUS                      |
| 23:16          | /          | /           | /                                |
| 15:8           | R/W        | 0x0         | MULF_CS                          |
| 7:1            | /          | /           | /                                |
| 0              | R/W        | 0x0         | MULF_EN                          |

#### 6.1.6.16 0x0104 CSIC Multi-Frame Interrupt Register (Default Value:0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: CSIC_MULF_INT_REG |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:18          | /          | /           | /                                |
| 17             | R/W1C      | 0x0         | MULF_ERR_PD                      |
| 16             | R/W1C      | 0x0         | MULF_DONE_PD                     |
| 15:2           | /          | /           | /                                |
| 1              | R/W        | 0x0         | MULF_ERR_EN                      |
| 0              | R/W        | 0x0         | MULF_DONE_EN                     |

#### 6.1.7 Parser Register Description

##### 6.1.7.1 0x0000 Parser Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: PRS_EN_REG                         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:17          | /          | /           | /                                                 |
| 16             | R/W        | 0x0         | NCSIC_EN<br>0: Reset and disable the NCSIC module |

| Offset: 0x0000 |            |             | Register Name: PRS_EN_REG                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
|                |            |             | 1: Enable the NCSIC module                                                                                                                             |
| 15             | R/W        | 0x0         | PCLK_EN<br>0: Gate pclk input<br>1: Enable pclk input                                                                                                  |
| 14:3           | /          | /           | /                                                                                                                                                      |
| 2              | R/W        | 0x0         | PRS_CH_MODE<br>0: Parser output channel 0~3 corresponding from input channel 0~3<br>1: Parser output channel 0~3 all from input channel 0 (MIPI SEHDR) |
| 1              | R/W        | 0x0         | PRS_MODE<br>0: Reserved<br>1: MCSI                                                                                                                     |
| 0              | R/W        | 0x0         | PRS_EN<br>0: Reset and disable the parser module<br>1: Enable the parser module                                                                        |

#### 6.1.7.2 0x0004 Parser NCSIC Interface Configuration Register (Default Value:0x0105\_0080)

| Offset: 0x0004 |            |             | Register Name: PRS_NCSI_IF_CFG_REG                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
|                |            |             | YUV420_LINE_ORDER<br>0: YUV420 input in Y-YC-Y-YC Line Order<br>1: YUV420 input in YC-Y-YC-Y Line Order                                                                                                                                                                                       |
| 30:28          | /          | /           | /                                                                                                                                                                                                                                                                                             |
|                |            |             | FIELD_DT_PCLK_SHIFT<br>Only for vsync detected field mode, the odd field permitted pclk shift = 4* FIELD_DT_PCLK_SHIFT                                                                                                                                                                        |
| 23:20          | R/W        | 0x0         | Source type<br>Bit 20~23 corresponding to the SRC_TYPES for channel0~3<br>0: Progressed<br>1: Interlaced                                                                                                                                                                                      |
|                |            |             | FIELD<br>Field polarity (For YUV HV timing)<br>0: negative (field=0 indicates odd, field=1 indicates even )<br>1: positive (field=1 indicates odd, field=0 indicates even )<br>Field sequence (For BT656 timing)<br>0: Normal sequence (field 0 first)<br>1: Inverse sequence (field 1 first) |
| 18             | R/W        | 0x1         | VREF_POL<br>Vref polarity                                                                                                                                                                                                                                                                     |

| Offset: 0x0004 |            |             | Register Name: PRS_NCSI_IF_CFG_REG                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                      |
|                |            |             | 0: negative<br>1: positive<br>This register is not applied to CCIR656 interface.                                                                                                                                                                                                                 |
| 17             | R/W        | 0x0         | HERF_POL<br>Href polarity<br>0: negative<br>1: positive<br>This register is not applied to CCIR656 interface.                                                                                                                                                                                    |
| 16             | R/W        | 0x1         | CLK_POL<br>Data clock type<br>0: active in rising edge<br>1: active in falling edge                                                                                                                                                                                                              |
| 15:14          | R/W        | 0x0         | Field_DT_MODE (only valid when CSI_IF is YUV and source type is interlaced)<br>00: by both field and vsync<br>01: by field<br>10: by vsync<br>11: reserved                                                                                                                                       |
| 13             | R/W        | 0x0         | DDR_SAMPLE_MODE_EN<br>0: disable<br>1: enable                                                                                                                                                                                                                                                    |
| 12:11          | R/W        | 0x0         | SEQ_8PLUS2<br>When select IF_DATA_WIDTH to be 8+2bit, odd/even pixel byte at CSI-D[11:4] will be rearranged to D[11:2]+2'b0 at the actual CSI data bus according to these sequences:<br>00: 6'bx+D[9:8], D[7:0]<br>01: D[9:2], 6'bx+D[1:0]<br>10: D[7:0], D[9:8]+6'bx<br>11: D[7:0], 6'bx+D[9:8] |
| 10:8           | R/W        | 0x0         | IF_DATA_WIDTH<br>000: 8 bit data bus<br>001: 10 bit data bus<br>010: 12 bit data bus<br>011: 8+2bit data bus<br>100: 2x8bit data bus<br>Others: Reserved                                                                                                                                         |
| 7:6            | R/W        | 0x2         | INPUT_SEQ<br>Input data sequence, only valid for YUV422 and YUV420 input format.<br><br>All data interleaved in one channel:<br>00: YUYV                                                                                                                                                         |

| Offset: 0x0004 |            |             | Register Name: PRS_NCSI_IF_CFG_REG                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
|                |            |             | 01: YVYU<br>10: UYVY<br>11: VYUY<br><br>Y and UV in separated channel:<br>x0: UV<br>x1: VU                                                                                                                                                                                                                                              |
| 5              | /          | /           | /                                                                                                                                                                                                                                                                                                                                       |
| 4:0            | R/W        | 0x0         | CSI_IF<br>YUV (separate syncs):<br>00000: RAW or YUV420/YUYV422 (each cycle one component input)<br>Others: Reserved<br><br>CCIR656 (embedded syncs):<br>00100: BT656 1 channel<br>01100: BT656 2 channels (All data interleaved in one data bus)<br>01110: BT656 4 channels (All data interleaved in one data bus)<br>Others: Reserved |

#### 6.1.7.3 0x000C Parser Capture Register (Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: PRS_CAP_REG                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                          |
| 29:26          | R/W        | 0x0         | CH3_FPS_DS<br>Fps down sample<br>0: no down sample<br>1: 1/2 fps, only receives the first frame every 2 frames<br>2: 1/3 fps, only receives the first frame every 3 frames<br>3: 1/4 fps, only receives the first frame every 4 frames<br>4: 1/5 fps, only receives the first frame every 4 frames<br>.....<br>15: 1/16 fps, only receives the first frame every 16 frames |
| 25             | R/W        | 0x0         | CH3_VCAP_ON<br>Video capture control: Capture the video image data stream on channel 3.<br>0: Disable video capture<br>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.                                                                                   |

| Offset: 0x000C |            |             | Register Name: PRS_CAP_REG                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | <p>1: Enable video capture<br/>The CSI starts capturing image data at the start of the next frame.</p>                                                                                                                                                                                                                                                                                                 |
| 24             | RC/W       | 0x0         | <p>CH3_SCAP_ON<br/>Still capture control: Capture a single still image frame on channel 3.<br/>0: Disable still capture<br/>1: Enable still capture<br/>The CSI module starts capturing image data at the start of the next frame. The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                         |
| 13:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |
| 21:18          | R/W        | 0x0         | <p>CH2_FPS_DS<br/>Fps down sample<br/>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p>              |
| 17             | R/W        | 0x0         | <p>CH2_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 2.<br/>0: Disable video capture<br/>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.<br/>1: Enable video capture<br/>The CSI starts capturing image data at the start of the next frame.</p> |
| 16             | RC/W       | 0x0         | <p>CH2_SCAP_ON<br/>Still capture control: Capture a single still image frame on channel 2.<br/>0: Disable still capture<br/>1: Enable still capture<br/>The CSI module starts capturing image data at the start of the next frame. The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x000C |            |             | Register Name: PRS_CAP_REG                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13:10          | R/W        | 0x0         | <p>CH1_FPS_DS<br/>Fps down sample<br/>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p>                   |
| 9              | R/W        | 0x0         | <p>CH1_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 1.<br/>0: Disable video capture<br/>If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.<br/><br/>1: Enable video capture<br/>The CSI starts capturing image data at the start of the next frame.</p> |
| 8              | RC/W       | 0x0         | <p>CH1_SCAP_ON<br/>Still capture control: Capture a single still image frame on channel 1.<br/>0: Disable still capture<br/>1: Enable still capture<br/>The CSI module starts capturing image data at the start of the next frame. The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0.</p>                                                              |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5:2            | R/W        | 0x0         | <p>CH0_FPS_DS<br/>Fps down sample<br/>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p>                   |
| 1              | R/W        | 0x0         | <p>CH0_VCAP_ON<br/>Video capture control: Capture the video image data stream on channel 0.<br/>0: Disable video capture</p>                                                                                                                                                                                                                                                                                |

| Offset: 0x000C |            |             | Register Name: PRS_CAP_REG                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                          |
|                |            |             | If video capture is in progress, the CSI stops capturing image data at the end of the current frame, and all of the current frame data is written to output FIFO.<br><br>1: Enable video capture<br>The CSI starts capturing image data at the start of the next frame.                                                              |
| 0              | RC/W       | 0x0         | CHO_SCAP_ON<br>Still capture control: Capture a single still image frame on channel 0.<br>0: Disable still capture.<br>1: Enable still capture<br>The CSI module starts capturing image data at the start of the next frame. The CSI module captures only one frame of image data. This bit is self cleared and always reads as a 0. |

#### 6.1.7.4 0x0010 Parser Signal Status Register (Default Value:0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: CSIC_PRS_SIGNAL_STA_REG                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:25          | /          | /           | /                                                                                          |
| 24             | R          | 0x0         | PCLK_STA<br>Indicates the pclk status<br>0: low<br>1: high                                 |
| 23:0           | R          | 0x0         | DATA_STA<br>Indicates the Dn status (n=0~23), MSB for D23, LSB for D0<br>0: low<br>1: high |

#### 6.1.7.5 0x0014 Parser NCSIC BT656 Header Configuration Register (Default Value:0x0302\_0100)

| Offset: 0x0014 |            |             | Register Name: CSIC_PRS_NCSIC_BT656_HEAD_CFG_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:28          | /          | /           | /                                                                                               |
| 27:24          | R/W        | 0x3         | CH3_ID<br>The low 4-bit of BT656 header for channel 3<br>Only valid in BT656 multi-channel mode |
| 23:20          | /          | /           | /                                                                                               |

| Offset: 0x0014 |            |             | Register Name: CSIC_PRS_NCSIC_BT656_HEAD_CFG_REG                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 19:16          | R/W        | 0x2         | CH2_ID<br>The low 4-bit of BT656 header for channel 2<br>Only valid in BT656 multi-channel mode |
| 15:12          | /          | /           | /                                                                                               |
| 11:8           | R/W        | 0x1         | CH1_ID<br>The low 4-bit of BT656 header for channel 1<br>Only valid in BT656 multi-channel mode |
| 7:4            | /          | /           | /                                                                                               |
| 3:0            | R/W        | 0x0         | CH0_ID<br>The low 4-bit of BT656 header for channel 0<br>Only valid in BT656 multi-channel mode |

#### 6.1.7.6 0x0024 Parser Channel\_0 Input Format Register (Default Value:0x0000\_0003)

| Offset: 0x0024 |            |             | Register Name: PRS_CH0_INFMT_REG                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved<br>0011: YUV422<br>0100: YUV420<br>Others: reserved |

#### 6.1.7.7 0x0028 Parser Channel\_0 Output Horizontal Size Register (Default Value:0x0500\_0000)

| Offset: 0x0028 |            |             | Register Name: PRS_CH0_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

### 6.1.7.8 0x002C Parser Channel\_0 Output Vertical Size Register (Default Value:0x02D0\_0000)

| Offset: 0x002C |            |             | Register Name: PRS_CH0_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2D0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. data is valid from this line. |

### 6.1.7.9 0x003C Parser Channel\_0 Input Parameter0 Register (Default Value:0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: PRS_CH0_INPUT_PARA0_REG        |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:1           | /          | /           | /                                             |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0: Progress<br>1: Interlace |

### 6.1.7.10 0x0034 Parser Channel\_0 Input Parameter1 Register (Default Value:0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: PRS_CH0_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

### 6.1.7.11 0x0038 Parser Channel\_0 Input Parameter2 Register (Default Value:0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: PRS_CH0_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

#### 6.1.7.12 0x003C Parser Channel\_0 Input Parameter3 Register (Default Value:0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: PRS_CH0_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 6.1.7.13 0x0040 Parser Channel\_0 Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: PRS_CH0_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0: disable<br>1: enable                                                                           |
| 0              | R/W        | 0x0         | INPUT_PARA0_INT_EN<br>0: disable<br>1: enable                                                                           |

#### 6.1.7.14 0x0044 Parser Channel\_0 Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: PRS_CH0_INT_STA_REG                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:3           | /          | /           | /                                                                                                                                                                              |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                      |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag set to 1. Write 1 to clear. |

**6.1.7.15 0x0048 Parser Channel\_0 Line Time Register (Default Value:0x0000\_0000)**

| Offset: 0x0048 |            |             | Register Name: PRS_CH0_LINE_TIME_REG                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:16          | RO         | 0x0         | PRS_CH0_HBLK_TIME<br>Time of H Blanking when vsync is valid<br>The unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH0_HSYN_TIME<br>Time of H SYNC when vsync is valid<br>The unit is csi_top_clk cycle     |

**6.1.7.16 0x0124 Parser Channel\_1 Input Format Register (Default Value:0x0000\_0003)**

| Offset: 0x0124 |            |             | Register Name: PRS_CH1_INFMT_REG                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved<br>0011: YUV422<br>0100: YUV420<br>Others: reserved |

**6.1.7.17 0x0128 Parser Channel\_1 Output Horizontal Size Register (Default Value:0x0500\_0000)**

| Offset: 0x0128 |            |             | Register Name: PRS_CH1_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

### 6.1.7.18 0x012C Parser Channel\_1 Output Vertical Size Register (Default Value:0x02D0\_0000)

| Offset: 0x012C |            |             | Register Name: PRS_CH1_OUTPUT_VSIZE_REG                            |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:29          | /          | /           | /                                                                  |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Valid line number of a frame.                           |
| 15:13          | /          | /           | /                                                                  |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start.<br>Data is valid from this line. |

### 6.1.7.19 0x0130 Parser Channel\_1 Input Parameter0 Register (Default Value:0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: PRS_CH1_INPUT_PARA0_REG        |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:1           | /          | /           | /                                             |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0: Progress<br>1: Interlace |

### 6.1.7.20 0x0134 Parser Channel\_1 Input Parameter1 Register (Default Value:0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: PRS_CH1_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

### 6.1.7.21 0x0138 Parser Channel\_1 Input Parameter2 Register (Default Value:0x0000\_0000)

| Offset: 0x0138 |            |             | Register Name: PRS_CH1_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |

| Offset: 0x0138 |            |             | Register Name: PRS_CH1_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 13:0           | R          | 0x0         | INPUT_HB                               |

#### 6.1.7.22 0x013C Parser Channel\_1 Input Parameter3 Register (Default Value:0x0000\_0000)

| Offset: 0x013C |            |             | Register Name: PRS_CH1_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 6.1.7.23 0x0140 Parser Channel\_1 Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0140 |            |             | Register Name: PRS_CH1_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0: Disable<br>1: Enable                                                                           |
| 0              | R/W        | 0x0         | INPUT_PARAO_INT_EN<br>0: Disable<br>1: Enable                                                                           |

#### 6.1.7.24 0x0144 Parser Channel\_1 Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0144 |            |             | Register Name: PRS_CH1_INT_STA_REG                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:3           | /          | /           | /                                                                                                           |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                   |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag is set to 1. Write 1 to clear. |

| Offset: 0x0144 |            |             | Register Name: PRS_CH1_INT_STA_REG                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag is set to 1. Write 1 to clear. |

#### 6.1.7.25 0x0148 Parser Channel\_1 Line Time Register (Default Value:0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: PRS_CH1_LINE_TIME_REG                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:16          | RO         | 0x0         | PRS_CH1_HBLK_TIME<br>Time of H Blanking when vsync is valid<br>The unit is csi_top_clk cycle. |
| 15:0           | RO         | 0x0         | PRS_CH1_HSYN_TIME<br>Time of H SYNC when vsync is valid<br>The unit is csi_top_clk cycle.     |

#### 6.1.7.26 0x0224 Parser Channel\_2 Input Format Register (Default Value:0x0000\_0003)

| Offset: 0x0224 |            |             | Register Name: PRS_CH2_INFMT_REG                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved<br>0011: YUV422<br>0100: YUV420<br>Others: reserved |

#### 6.1.7.27 0x0228 Parser Channel\_2 Output Horizontal Size Register (Default Value:0x0500\_0000)

| Offset: 0x0228 |            |             | Register Name: PRS_CH2_OUTPUT_HSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line. |
| 15:13          | /          | /           | /                                                               |

| Offset: 0x0228 |            |             | Register Name: PRS_CH2_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

#### 6.1.7.28 0x022C Parser Channel\_2 Output Vertical Size Register (Default Value:0x02D0\_0000)

| Offset: 0x022C |            |             | Register Name: PRS_CH2_OUTPUT_VSIZE_REG                         |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:29          | /          | /           | /                                                               |
| 28:16          | R/W        | 0x2D0       | VER_LEN<br>Valid line number of a frame.                        |
| 15:13          | /          | /           | /                                                               |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start. Data is valid from this line. |

#### 6.1.7.29 0x0230 Parser Channel\_2 Input Parameter0 Register (Default Value:0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: PRS_CH2_INPUT_PARA0_REG      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |

#### 6.1.7.30 0x0234 Parser Channel\_2 Input Parameter1 Register (Default Value:0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: PRS_CH2_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

### 6.1.7.31 0x0238 Parser Channel\_2 Input Parameter2 Register (Default Value:0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: PRS_CH2_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

### 6.1.7.32 0x023C Parser Channel\_2 Input Parameter3 Register (Default Value:0x0000\_0000)

| Offset: 0x023C |            |             | Register Name: PRS_CH2_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

### 6.1.7.33 0x0240 Parser Channel\_2 Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: PRS_CH2_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0: disable<br>1: enable                                                                           |
| 0              | R/W        | 0x0         | INPUT_PARAO_INT_EN<br>0: disable<br>1: enable                                                                           |

### 6.1.7.34 0x0244 Parser Channel\_2 Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0244 |            |             | Register Name: PRS_CH2_INT_STA_REG |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:3           | /          | /           | /                                  |

| Offset: 0x0244 |            |             | Register Name: PRS_CH2_INT_STA_REG                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                      |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag set to 1. Write 1 to clear. |

#### 6.1.7.35 0x0248 Parser Channel\_2 Line Time Register (Default Value:0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: PRS_CH2_LINE_TIME_REG                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:16          | RO         | 0x0         | PRS_CH2_HBLK_TIME<br>Time of H Blanking when vsync is valid<br>The unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH2_HSYN_TIME<br>Time of H SYNC when vsync is valid<br>The unit is csi_top_clk cycle     |

#### 6.1.7.36 0x0324 Parser Channel\_3 Input Format Register (Default Value:0x0000\_0003)

| Offset: 0x0324 |            |             | Register Name: PRS_CH3_INFMT_REG                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                                          |
| 3:0            | R/W        | 0x3         | INPUT_FMT<br>Input data format<br>0000: RAW stream<br>0001: reserved<br>0010: reserved<br>0011: YUV422<br>0100: YUV420<br>Others: reserved |

### 6.1.7.37 0x0328 Parser Channel\_3 Output Horizontal Size Register (Default Value:0x0500\_0000)

| Offset: 0x0328 |            |             | Register Name: PRS_CH3_OUTPUT_HSIZE_REG                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:29          | /          | /           | /                                                                         |
| 28:16          | R/W        | 0x500       | HOR_LEN<br>Horizontal pixel unit length. Valid pixel of a line.           |
| 15:13          | /          | /           | /                                                                         |
| 12:0           | R/W        | 0x0         | HOR_START<br>Horizontal pixel unit start. Pixel is valid from this pixel. |

### 6.1.7.38 0x032C Parser Channel\_3 Output Vertical Size Register (Default Value:0x02D0\_0000)

| Offset: 0x032C |            |             | Register Name: PRS_CH3_OUTPUT_VSIZE_REG                            |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:29          | /          | /           | /                                                                  |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Valid line number of a frame.                           |
| 15:13          | /          | /           | /                                                                  |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start.<br>Data is valid from this line. |

### 6.1.7.39 0x0330 Parser Channel\_3 Input Parameter0 Register (Default Value:0x0000\_0000)

| Offset: 0x0330 |            |             | Register Name: PRS_CH3_INPUT_PARA0_REG      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:1           | /          | /           | /                                           |
| 0              | R          | 0x0         | INPUT_SRC_TYPE<br>0:Progress<br>1:Interlace |

### 6.1.7.40 Parser Channel\_3 Input Parameter1 Register (Default Value:0x0000\_0000)

| Offset: 0x0334 |            |             | Register Name: PRS_CH3_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |
| 29:16          | R          | 0x0         | INPUT_VT<br>INPUT_VT = INPUT_VB+INPUT_Y |

| Offset: 0x0334 |            |             | Register Name: PRS_CH3_INPUT_PARA1_REG  |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 15:14          | /          | /           | /                                       |
| 13:0           | R          | 0x0         | INPUT_HT<br>INPUT_HT = INPUT_HB+INPUT_X |

#### 6.1.7.41 0x0338 Parser Channel\_3 Input Parameter2 Register (Default Value:0x0000\_0000)

| Offset: 0x0338 |            |             | Register Name: PRS_CH3_INPUT_PARA2_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_VB                               |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_HB                               |

#### 6.1.7.42 0x033C Parser Channel\_3 Input Parameter3 Register(Default Value:0x0000\_0000)

| Offset: 0x033C |            |             | Register Name: PRS_CH3_INPUT_PARA3_REG |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:30          | /          | /           | /                                      |
| 29:16          | R          | 0x0         | INPUT_Y                                |
| 15:14          | /          | /           | /                                      |
| 13:0           | R          | 0x0         | INPUT_X                                |

#### 6.1.7.43 0x0340 Parser Channel\_3 Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0340 |            |             | Register Name: PRS_CH3_INT_EN_REG                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                       |
| 2              | R/W        | 0x0         | MUL_ERR_INT_EN<br>Multi-channel writing error<br>Indicates error has been detected for writing data to a wrong channel. |
| 1              | R/W        | 0x0         | INPUT_PARA1_INT_EN<br>0:disable<br>1:enable                                                                             |
| 0              | R/W        | 0x0         | INPUT_PARA0_INT_EN<br>0:disable<br>1:enable                                                                             |

#### 6.1.7.44 0x0344 Parser Channel\_3 Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: PRS_CH3_INT_STA_REG                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:3           | /          | /           | /                                                                                                                                                                                 |
| 2              | R/W1C      | 0x0         | MUL_ERR_PD<br>Multi-channel writing error                                                                                                                                         |
| 1              | R/W1C      | 0x0         | INPUT_SRC_PD1<br>When the parser input parameter0 register update, this flag is set to 1. Write 1 to clear.                                                                       |
| 0              | R/W1C      | 0x0         | INPUT_SRC_PDO<br>When the parser input parameter1 register, parser input parameter2 register or parser input parameter3 register update, this flag is set to 1. Write 1 to clear. |

#### 6.1.7.45 0x0348 Parser Channel\_3 Line Time Register (Default Value:0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: PRS_CH3_LINE_TIME_REG                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:16          | RO         | 0x0         | PRS_CH3_HBLK_TIME<br>Time of H Blanking when vsync is valid<br>The unit is csi_top_clk cycle |
| 15:0           | RO         | 0x0         | PRS_CH3_HSYN_TIME<br>Time of H SYNC when vsync is valid<br>The unit is csi_top_clk cycle     |

#### 6.1.7.46 0x0500 CSIC Parser NCSIC RX Signal0 Delay Adjust Register (Default Value:0x0000\_0000)

| Offset: 0x0500 |            |             | Register Name: CSIC_PRS_NCSIC_RX_SIGNAL0_DLY_ADJ_REG |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:29          | /          | /           | /                                                    |
| 28:24          | R/W        | 0x0         | Filed_dly<br>32 Step for adjust, 1 step = 0.2 ns     |
| 23:21          | /          | /           | /                                                    |
| 20:16          | R/W        | 0x0         | Vsync_dly<br>32 Step for adjust, 1 step = 0.2 ns     |
| 15:13          | /          | /           | /                                                    |
| 12:8           | R/W        | 0x0         | Hsync_dly<br>32 Step for adjust, 1 step = 0.2 ns     |

| Offset: 0x0500 |            |             | Register Name: CSIC_PRS_NCSIC_RX_SIGNAL0_DLY_ADJ_REG |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 7:5            | /          | /           | /                                                    |
| 4:0            | R/W        | 0x0         | Pclk_dly<br>32 Step for adjust, 1 step = 0.2 ns      |

#### 6.1.7.47 0x0514 CSIC Parser NCSIC RX Signal5 Delay Adjust Register (Default Value:0x0000\_0000)

| Offset: 0x0514 |            |             | Register Name: CSIC_PRS_NCSIC_RX_SIGNAL5_DLY_ADJ_REG |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:29          | /          | /           | /                                                    |
| 28:24          | R/W        | 0x0         | D7_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 23:21          | /          | /           | /                                                    |
| 20:16          | R/W        | 0x0         | D6_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 15:13          | /          | /           | /                                                    |
| 12:8           | R/W        | 0x0         | D5_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 7:5            | /          | /           | /                                                    |
| 4:0            | R/W        | 0x0         | D4_dly<br>32 Step for adjust, 1 step = 0.2 ns        |

#### 6.1.7.48 0x0518 CSIC Parser NCSIC RX Signal6 Delay Adjust Register (Default Value:0x0000\_0000)

| Offset: 0x0518 |            |             | Register Name: CSIC_PRS_NCSIC_RX_SIGNAL6_DLY_ADJ_REG |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:29          | /          | /           | /                                                    |
| 28:24          | R/W        | 0x0         | D3_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 23:21          | /          | /           | /                                                    |
| 20:16          | R/W        | 0x0         | D2_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 15:13          | /          | /           | /                                                    |
| 12:8           | R/W        | 0x0         | D1_dly<br>32 Step for adjust, 1 step = 0.2 ns        |
| 7:5            | /          | /           | /                                                    |
| 4:0            | R/W        | 0x0         | D0_dly<br>32 Step for adjust, 1 step = 0.2 ns        |

## 6.1.8 CSIC DMA Register Description

### 6.1.8.1 0x0000 CSIC DMA Enable Register (Default Value:0x7000\_0000)

| Offset:0x0000 |            |             | Register Name: CSIC_DMA_EN_REG                                                                                                                                                               |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31            | R/W        | 0x0         | VER_EN                                                                                                                                                                                       |
| 30            | R/W        | 0x1         | VFLIP_BUF_ADDR_CFG_MODE<br>Vflip buffer address set by software or calculated by hardware<br>0: Hardware<br>1: Software                                                                      |
| 29            | R/W        | 0x1         | BUF_LENGTH_CFG_MODE<br>Buffer length set by software or calculated by hardware<br>0: Hardware<br>1: Software                                                                                 |
| 28            | R/W        | 0x1         | FLIP_SIZE_CFG_MODE<br>FLIP SIZE set by software or calculated by hardware<br>0: Hardware<br>1: Software                                                                                      |
| 27:8          | /          | /           | /                                                                                                                                                                                            |
| 7             | R/W        | 0x0         | BUF_ADDR_MODE<br>0: Buffer Address Register Mode<br>1: Buffer Address FIFO Mode                                                                                                              |
| 6             | R/W        | 0x0         | VI_TO_CNT_EN<br>Enable Video Input Timeout counter, add 1 when there is no effective video input in a 12M clock, clear to 0 when detecting effective video input.<br>0: Disable<br>1: Enable |
| 5             | R/W        | 0x0         | FRAME_CNT_EN<br>When BK_TOP_EN is enabled, setting 1 to this bit indicates the Frame counter starts to add.<br>0: Disable<br>1: Enable                                                       |
| 4             | R/W        | 0x0         | DMA_EN<br>When BK_TOP_EN is enabled, setting 1 to this bit indicates the module works in DMA mode.<br>0: Disable<br>1: Enable                                                                |
| 3             | /          | /           | /                                                                                                                                                                                            |
| 2             | R/W        | 0x0         | CLK_CNT_SPL<br>Sampling time for clk counter per frame<br>0: Sampling clock counter every frame done<br>1: Sampling clock counter every vsync                                                |

| Offset:0x0000 |            |             | Register Name: CSIC_DMA_EN_REG           |
|---------------|------------|-------------|------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                              |
| 1             | R/W        | 0x0         | CLK_CNT_EN<br>clk count per frame enable |
| 0             | R/W        | 0x0         | BK_TOP_EN<br>0: Disable<br>1: Enable     |

#### 6.1.8.2 0x0004 CSIC DMA Configuration Register (Default Value:0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CSIC_DMA_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:24          | R/W        | 0x0         | PAD_VAL<br>Padding value when OUTPUT_FMT is prgb888<br>0x00–0xff                                                                                                                                                                                                                                                                                                                                                                                                             |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21             | R/W        | 0x0         | YUV 10-bit input cut to 8-bit<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 20             | R/W        | 0x0         | YUV 10-bit store configuration<br>0: YUV 10-bit stored in low 10-bit of a 16-bit word<br>1: YUV 10-bit stored in high 10-bit of a 16-bit word                                                                                                                                                                                                                                                                                                                                |
| 19:16          | R/W        | 0x0         | OUTPUT_FMT<br>Output data format<br>When the input format is set to RAW stream<br>0000: field-raw-8<br>0001: field-raw-10<br>0010: field-raw-12<br>0011: reserved<br>0100: field-rgb565<br>0101: field-rgb888<br>0110: field-prgb888<br>0111: reserved<br>1000: frame-raw-8<br>1001: frame-raw-10<br>1010: frame-raw-12<br>1011: reserved<br>1100: frame-rgb565<br>1101: frame-rgb888<br>1110: frame-prgb888<br>1111: reserved<br><br>When the input format is set to YUV422 |

| Offset: 0x0004 |            |             | Register Name: CSIC_DMA_CFG_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>0000: field planar YCbCr 422<br/>     0001: field planar YCbCr 420<br/>     0010: frame planar YCbCr 420<br/>     0011: frame planar YCbCr 422<br/>     0100: field planar YCbCr 422 UV combined (UV sequence)<br/>     0101: field planar YCbCr 420 UV combined (UV sequence)<br/>     0110: frame planar YCbCr 420 UV combined (UV sequence)<br/>     0111: frame planar YCbCr 422 UV combined (UV sequence)<br/>     1000: filed planar YCbCr 422 UV combined (VU sequence)<br/>     1001: field planar YCbCr 420 UV combined (VU sequence)<br/>     1010: frame planar YCbCr 420 UV combined (VU sequence)<br/>     1011: frame planar YCbCr 422 UV combined (VU sequence)<br/>     1100: reserved<br/>     1101: field YCbCr 400<br/>     1110: reserved<br/>     1111: frame YCbCr 400</p> <p>When the input format is set to YUV420</p> <p>0000: reserved<br/>     0001: field planar YCbCr 420<br/>     0010: frame planar YCbCr 420<br/>     0011: reserved<br/>     0100: reserved<br/>     0101: field planar YCbCr 420 UV combined (UV sequence)<br/>     0110: frame planar YCbCr 420 UV combined (UV sequence)<br/>     0111~1000: reserved<br/>     1001: field planar YCbCr 420 UV combined (VU sequence)<br/>     1010: frame planar YCbCr 420 UV combined (VU sequence)<br/>     1011~1100: reserved<br/>     1101: field YCbCr 400<br/>     1110: reserved<br/>     1111: frame YCbCr 400</p> |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13             | R/W        | 0x0         | <p>VFLIP_EN<br/>     Vertical flip enable<br/>     When enabled, the received data will be arranged in vertical flip.<br/>     0: Disable<br/>     1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12             | R/W        | 0x0         | <p>HFLIP_EN<br/>     Horizontal flip enable<br/>     When enabled, the received data will be arranged in horizontal flip.<br/>     0: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0004 |            |             | Register Name: CSIC_DMA_CFG_REG                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | 1: Enable                                                                                                                                                                                                                                                                                                                                                                                |
| 11:10          | R/W        | 0x0         | <p>FIELD_SEL<br/>Field selection</p> <p>00: Capturing with field 0<br/>01: Capturing with field 1<br/>10: Capturing with either field<br/>11: Reserved</p>                                                                                                                                                                                                                               |
| 9:6            | R/W        | 0x0         | <p>FPS_DS<br/>Fps down sample</p> <p>0: no down sample<br/>1: 1/2 fps, only receives the first frame every 2 frames<br/>2: 1/3 fps, only receives the first frame every 3 frames<br/>3: 1/4 fps, only receives the first frame every 4 frames<br/>4: 1/5 fps, only receives the first frame every 4 frames<br/>.....<br/>15: 1/16 fps, only receives the first frame every 16 frames</p> |
| 5:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                        |
| 1:0            | R/W        | 0x0         | <p>MIN_SDR_WR_SIZE<br/>Minimum size of SDRAM block write</p> <p>00: 256 bytes (if hflip is enabled, always select 256 bytes)<br/>01: 512 bytes<br/>10: 1K bytes<br/>11: 2K bytes</p>                                                                                                                                                                                                     |

#### 6.1.8.3 0x0010 CSIC DMA Horizontal Size Register (Default Value:0x0500\_0000)

| Offset: 0x0010 |            |             | Register Name: CSIC_DMA_HSIZE_REG                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:29          | /          | /           | /                                                                                                                                                        |
| 28:16          | R/W        | 0x500       | <p>HOR_LEN</p> <p>When BK_TOP_EN is enabled, DMA_EN is enabled, these bits indicate Horizontal pixel unit length. Valid pixel of a line in DMA mode.</p> |
| 15:13          | /          | /           | /                                                                                                                                                        |
| 12:0           | R/W        | 0x0         | <p>HOR_START</p> <p>Horizontal pixel unit start.</p> <p>Pixel is valid from this pixel.</p>                                                              |

#### 6.1.8.4 0x0014 CSIC DMA Vertical Size Register (Default Value:0x02D0\_0000)

| Offset: 0x0014 |            |             | Register Name: CSIC_DMA_VSIZE_REG                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:29          | /          | /           | /                                                                                                                      |
| 28:16          | R/W        | 0x2D0       | VER_LEN<br>When BK_TOP_EN is enabled, DMA_EN is enabled, these bits indicate Valid line number of a frame in DMA mode. |
| 15:13          | /          | /           | /                                                                                                                      |
| 12:0           | R/W        | 0x0         | VER_START<br>Vertical line start<br>Data is valid from this line.                                                      |

#### 6.1.8.5 0x0020 CSIC DMA FIFO 0 Output Buffer-A Address Register (Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CSIC_DMA_F0_BUFA_REG                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:0           | R/W        | 0x0         | F0_BUFA<br>When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled, these bits indicate output address of overhead data in FBC mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC_EN is disabled, these bits indicate FIFO 0 output buffer-A address in DMA mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, LBC_EN is enabled, these bits indicate the output buffer address in LBC mode. |

#### 6.1.8.6 0x0024 CSIC DMA FIFO 0 Output Buffer-A Address Result Register (Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CSIC_DMA_F0_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F0_BUFA_RESULT<br>Indicate the final F0_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

### 6.1.8.7 0x0028 CSIC DMA FIFO 1 Output Buffer-A Address Register (Default Value:0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CSIC_DMA_F1_BUFA_REG                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                  |
| 31:0           | R/W        | 0x0         | F1_BUFA<br>When BK_TOP_EN is enabled, FBC_EN is enabled, DMA_EN is disabled, these bits indicate the output address of compressed data in FBC mode.<br>When BK_TOP_EN is enabled, FBC_EN is disabled, DMA_EN is enabled, these bits indicate the FIFO 1 output buffer-A address in DMA mode. |

### 6.1.8.8 0x002C CSIC DMA FIFO 1 Output Buffer-A Address Result Register (Default Value:0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: CSIC_DMA_F1_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F1_BUFA_RESULT<br>Indicate the final F1_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

### 6.1.8.9 0x0030 CSIC DMA FIFO 2 Output Buffer-A Address Register (Default Value:0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CSIC_DMA_F2_BUFA_REG        |
|----------------|------------|-------------|--------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                |
| 31:0           | R/W        | 0x0         | F2_BUFA<br>FIFO 2 output buffer-A address. |

### 6.1.8.10 0x0034 CSIC DMA FIFO 2 Output Buffer-A Address Result Register (Default Value:0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: CSIC_DMA_F2_BUFA_RESULT_REG                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:0           | RO         | 0x0         | F2_BUFA_RESULT<br>Indicate the final F2_BUFA address used for DMA or FBC after software configuration or hardware calculation from Buffer-A address register or buffer address fifo. Only used for debug. |

### 6.1.8.11 0x0038 CSIC DMA Buffer Length Register (Default Value:0x0280\_0500)

| Offset: 0x0038 |            |             | Register Name: CSIC_DMA_BUF_LEN_REG                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 31:30          | /          | /           | /                                                                                                                                                                                                                         |
| 29:16          | R/W        | 0x280       | BUF_LEN_C<br>DMA_MODE: Buffer length of chroma C in a line. Unit is byte.<br>LBC_MODE: Buffer length Stride of luminance Y in ONLY Y line.<br>Unit is byte.<br>Only Readable when BUF_LENGTH_CFG_MODE is set 0.           |
| 15:14          | /          | /           | /                                                                                                                                                                                                                         |
| 13:0           | R/W        | 0x500       | BUF_LEN<br>DMA_MODE: Buffer length of luminance Y in a line. Unit is byte.<br>LBC_MODE: Buffer length Stride of luminance Y and chroma C in<br>YC line. Unit is byte.<br>Only Readable when BUF_LENGTH_CFG_MODE is set 0. |

### 6.1.8.12 0x003C CSIC DMA Flip Size Register (Default Value:0x02D0\_0500)

| Offset: 0x003C |            |             | Register Name: CSIC_DMA_FLIP_SIZE_REG                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                   |
| 31:29          | /          | /           | /                                                                                                                                             |
| 28:16          | R/W        | 0x2d0       | VER_LEN<br>Vertical line number when in VFLIP mode. Unit is line.<br>Only Readable when FLIP_SIZE_CFG_MODE is set to 0.                       |
| 15:14          | /          | /           | /                                                                                                                                             |
| 13:0           | R/W        | 0x500       | VALID_LEN<br>Valid components of a line when in HFLIP mode. Unit is pixel<br>component.<br>Only Readable when FLIP_SIZE_CFG_MODE is set to 0. |

### 6.1.8.13 0x0040 CSIC DMA Video Input Timeout Threshold0 Register (Default Value:0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: CSIC_DMA_VI_TO_TH0_REG                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:0           | R/W        | 0x0         | Video Input Timeout Threshold0<br>Set VIDEO_INPUT_TO_INT_PD when VI Counter reaches TH0<br>after VI_TO_CNT_EN is set, the Time Unit is a 12M clock period. |

#### 6.1.8.14 0x0044 CSIC DMA Video Input Timeout Threshold1 Register(Default Value:0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: CSIC_DMA_VI_TO_TH1_REG                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | Video Input Timeout Threshold1<br>Set VIDEO_INPUT_TO_INT_PD when VI Counter reaches TH1 after getting the first frame has been input, the Time Unit is a 12M clock period. |

#### 6.1.8.15 0x0048 CSIC DMA Video Input Timeout Counter Value Register (Default Value:0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: CSIC_DMA_VI_TO_CNT_VAL_REG                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31:0           | R          | 0x0         | Video Input Timeout Counter Value<br>Indicate the current value of Video Input Timeout Counter |

#### 6.1.8.16 0x004C CSIC DMA Capture Status Register (Default Value:0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: CSIC_DMA_CAP_STA_REG                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2              | R          | 0x0         | FIELD_STA<br>The status of the received field<br>0: Field 0<br>1: Field 1                                                                                                                                                                                                                                                                                                                                                 |
| 1              | R          | 0x0         | VCAP_STA<br>Video capture in progress<br>Indicates the CSI is capturing video image data (multiple frames).<br>The bit is set at the start of the first frame after enabling video capture. When software disables video capture, it clears itself after the last pixel of the current frame is captured.                                                                                                                 |
| 0              | R          | 0x0         | SCAP_STA<br>Still capture in progress<br>Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It clears itself after the last pixel of the first frame is captured.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means filed end. |

## 6.1.8.17 0x0050 CSIC DMA Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: CSIC_DMA_INT_EN_REG                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                                                                          |
| 15             | R/W        | 0x0         | FRM_LOST_INT_EN<br>Set an INT when frame starts with empty Buffer Address FIFO, only use in BUF Address FIFO MODE.                                                                                         |
| 14             | R/W        | 0x0         | STORED_FRM_CNT_INT_EN<br>Set an INT when the value of CSIC_DMA_STORED_FRM_CNT reaches CSIC_DMA_STORED_FRM_THRESHOLD, only use in BUF Address FIFO MODE.                                                    |
| 13             | R/W        | 0x0         | BUF_ADDR_FIFO_INT_EN<br>Set an INT when content in BUF Address FIFO less than CSIC_DMA_BUFA_FIFO_THRESHOLD, only use in BUF Address FIFO MODE.                                                             |
| 12             | R/W        | 0x0         | VIDEO_INPUT_TO_INT_EN<br>Set an INT when no video input exceeds the setting threshold time                                                                                                                 |
| 11             | R/W        | 0x0         | CLR_FRAME_CNT_INT_EN<br>Set a INT when clear Frame cnt.                                                                                                                                                    |
| 10:8           | /          | /           | /                                                                                                                                                                                                          |
| 7              | R/W        | 0x0         | VS_INT_EN<br>vsync flag<br>The bit is set when vsync come. And at this time load the buffer address for the coming frame. So after this irq come, changing the buffer address could only effect next frame |
| 6              | R/W        | 0x0         | HB_OF_INT_EN<br>Hblank FIFO overflow<br>The bit is set when 3 FIFOs still overflow after the hblank.                                                                                                       |
| 5              | R/W        | 0x0         | LC_INT_EN<br>Line counter flag<br>The bit is set when the specific line has been written to dram every frame. The line number is set in the line counter register.                                         |
| 4              | R/W        | 0x0         | FIFO2_OF_INT_EN<br>FIFO 2 overflow<br>The bit is set when the FIFO 2 became overflow.                                                                                                                      |
| 3              | R/W        | 0x0         | FIFO1_OF_INT_EN<br>FIFO 1 overflow<br>The bit is set when the FIFO 1 became overflow.                                                                                                                      |
| 2              | R/W        | 0x0         | FIFO0_OF_INT_EN<br>FIFO 0 overflow<br>The bit is set when the FIFO 0 became overflow.                                                                                                                      |
| 1              | R/W        | 0x0         | FD_INT_EN                                                                                                                                                                                                  |

| Offset: 0x0050 |            |             | Register Name: CSIC_DMA_INT_EN_REG                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>Frame done<br/>Indicates the CSI has finished capturing an image frame. Applies to video capture mode. The bit is set after each completed frame capturing data is written to buffer as long as video capture remains enabled.</p>                                                                                                                                                                                                                                      |
| 0              | R/W        | 0x0         | <p>CD_INT_EN<br/>Capture done<br/>Indicates the CSI has completed capturing the image data.<br/>For still capture, the bit is set when one frame data has been written to buffer.<br/>For video capture, the bit is set when the last frame has been written to buffer after video capture has been disabled.<br/>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, the other frame end means field end.</p> |

#### 6.1.8.18 0x0054 CSIC DMA Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: CSIC_DMA_INT_STA_REG                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                               |
| 15             | R/W1C      | 0x0         | <p>FRM_LOST_INT_PD<br/>Set an INT when frame starts with empty Buffer Address FIFO, only use in BUF Address FIFO MODE.</p>                                      |
| 14             | R/W1C      | 0x0         | <p>STORED_FRM_CNT_INT_PD<br/>Set an INT when the value of CSIC_DMA_STORED_FRM_CNT reaches CSIC_DMA_STORED_FRM_THRESHOLD, only use in BUF Address FIFO MODE.</p> |
| 13             | R/W1C      | 0x0         | <p>BUF_ADDR_FIFO_INT_PD<br/>Set an INT when content in BUF Address FIFO less than CSIC_DMA_BUFA_FIFO_THRESHOLD, only use in BUF Address FIFO MODE.</p>          |
| 12             | R/W1C      | 0x0         | <p>VIDEO_INPUT_TO_INT_PD<br/>Set an INT Pending when no video input exceeds the setting threshold time.</p>                                                     |
| 11             | R/W1C      | 0x0         | <p>CLR_FRAME_CNT_INT<br/>Set a INT when clear Frame cnt.</p>                                                                                                    |
| 10:8           | /          | /           | /                                                                                                                                                               |
| 7              | R/W1C      | 0x0         | <p>VS_PD<br/>vsync flag</p>                                                                                                                                     |
| 6              | R/W1C      | 0x0         | <p>LI_OF_PD</p>                                                                                                                                                 |

| Offset: 0x0054 |            |             | Register Name: CSIC_DMA_INT_STA_REG       |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
|                |            |             | Line information FIFO (16 lines) overflow |
| 5              | R/W1C      | 0x0         | LC_PD<br>Line counter flag                |
| 4              | R/W1C      | 0x0         | FIFO2_OF_PD<br>FIFO 2 overflow            |
| 3              | R/W1C      | 0x0         | FIFO1_OF_PD<br>FIFO 1 overflow            |
| 2              | R/W1C      | 0x0         | FIFO0_OF_PD<br>FIFO 0 overflow            |
| 1              | R/W1C      | 0x0         | FD_PD<br>Frame done                       |
| 0              | R/W1C      | 0x0         | CD_PD<br>Capture done                     |

#### 6.1.8.19 0x0058 CSIC DMA Line Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: CSIC_DMA_LINE_CNT_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:13          | /          | /           | /                                                                                                                            |
| 12:0           | R/W        | 0x0         | LINE_CNT_NUM<br>The LINE_CNT_NUM value is set by user,when internal line counter reach the set value, the LC_PD will be set. |

#### 6.1.8.20 0x005C CSIC DMA Frame Counter Register (Default Value:0x0001\_0000)

| Offset: 0x005C |            |             | Register Name: CSIC_DMA_FRM_CNT_REG                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31             | R/W1C      | 0x0         | FRM_CNT_CLR<br>When the bit set to 1, Frame cnt is cleared to 0.                                                                                                                               |
| 30:16          | R/W        | 0x1         | PCLK_DMA_CLR_DISTANCE<br>Frame cnt clear cycle<br>$N*T_{SYNC}$                                                                                                                                 |
| 15:0           | R          | 0x0         | FRM_CNT<br>Counter value of frame. When frame done comes, the internal counter value add 1, and when the reg full, it is cleared to 0 .<br>When parser sent a sync signal, it is cleared to 0. |

### 6.1.8.21 0x0060 CSIC DMA Frame Clock Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0060 |            |             | Register Name: CSIC_DMA_FRM_CLK_CNT_REG                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                    |
| 23:0           | R          | 0x0         | FRM_CLK_CNT<br>Counter value between every frame. For instant hardware frame rate statics.<br>The internal counter is added by one every 12 MHz clock cycle. When frame done or vsync comes, the internal counter value is sampled to FRM_CLK_CNT, and cleared to 0. |

### 6.1.8.22 0x0064 CSIC DMA Accumulated and Internal Clock Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: CSIC_DMA_ACC_ITNL_CLK_CNT_REG                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                |
| 31:24          | R/WC       | 0x0         | ACC_CLK_CNT<br>The accumulated value of FRM_CLK_CNT for software frame rate statics. Every interrupt of frame is done, the software checks this accumulated value and clears it to 0. If the ACC_CLK_CNT is larger than 1, the software has lost frame.<br><br>When frame done or vsync comes, ACC_CLK_CNT = ACC_CLK_CNT + 1, and cleared to 0 when writing this register. |
| 23:0           | R          | 0x0         | ITNL_CLK_CNT<br>The instant value of internal frame clock counter.<br>When frame done interrupt comes, the software can query this counter for judging whether it is the time for updating the double buffer address registers.                                                                                                                                            |

### 6.1.8.23 0x0068 CSIC DMA FIFO Statistic Register (Default Value:0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: CSIC_DMA_FIFO_STAT_REG                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:30          | /          | /           | /                                                                                                                       |
| 29:16          | R          | 0x0         | Line Index<br>Indicates the line index in current vsync.                                                                |
| 15:13          | /          | /           | /                                                                                                                       |
| 12:0           | R          | 0x0         | FIFO_FRM_MAX<br>Indicates the maximum depth of FIFO being occupied for whole frame. Update at every vsync or framedone. |

#### 6.1.8.24 0x006C CSIC DMA FIFO Threshold Register (Default Value:0x0000\_0400)

| Offset: 0x006C |            |             | Register Name: CSIC_DMA_FIFO_THRS_REG                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:12          | /          | /           | /                                                                                           |
| 11:0           | R/W        | 0x400       | FIFO_THRS<br>When FIFO occupied memory exceed the threshold, dram frequency can not change. |

#### 6.1.8.25 0x0070 CSIC DMA PCLK Statistic Register (Default Value:0x0000\_7FFF)

| Offset: 0x0070 |            |             | Register Name: CSIC_DMA_PCLK_STAT_REG                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31             | /          | /           | /                                                                                                                      |
| 30:16          | R          | 0x0         | PCLK_CNT_LINE_MAX<br>Indicates maximum pixel clock counter value for each line.<br>Update at every vsync or framedone. |
| 15             | /          | /           | /                                                                                                                      |
| 14:0           | R          | 0x7FFF      | PCLK_CNT_LINE_MIN<br>Indicates minimum pixel clock counter value for each line.<br>Update at every vsync or framedone. |

#### 6.1.8.26 0x0080 CSIC DMA BUF Address FIFO0 Entry Register (Default Value:0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO0_ENTRY_REG                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:0           | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO0_ENTRY<br>FIFO Entry of Buffer Address FIFO0 for input frames to be stored,<br>only used in Buffer Addr FIFO Mode |

#### 6.1.8.27 0x0084 CSIC DMA BUF Address FIFO1 Entry Register (Default Value:0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO1_ENTRY_REG                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:0           | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO1_ENTRY<br>FIFO Entry of Buffer Address FIFO1 for input frames to be stored,<br>only used in Buffer Addr FIFO Mode. |

### 6.1.8.28 0x0088 CSIC DMA BUF Address FIFO2 Entry Register (Default Value:0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO2_ENTRY_REG                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 31:0           | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO2_ENTRY<br>FIFO Entry of Buffer Address FIFO2 for input frames to be stored, only used in Buffer Addr FIFO Mode. |

### 6.1.8.29 0x008C CSIC DMA BUF Threshold Register (Default Value:0x0020\_0000)

| Offset: 0x008C |            |             | Register Name: CSIC_DMA_BUF_TH_REG                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 31:21          | /          | /           | /                                                                                                                                                         |
| 21:16          | R/W        | 0x20        | CSIC_DMA_STORED_FRM_THRESHOLD<br>when stored frame counter value reaches the threshold , counter is cleared to 0 , only used in Buffer Addr FIFO Mode.    |
| 15:6           | /          | /           | /                                                                                                                                                         |
| 5:0            | R/W        | 0x0         | CSIC_DMA_BUF_ADDR_FIFO_THRESHOLD<br>when content in Buffer Address FIFO less than the threshold, an interrupt is set, only used in Buffer Addr FIFO Mode. |

### 6.1.8.30 0x0090 CSIC DMA BUF Address FIFO Content Register (Default Value:0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: CSIC_DMA_BUF_ADDR_FIFO_CON_REG                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:22          | /          | /           | /                                                                                                                                |
| 21:16          | RO         | 0x0         | CSIC_DMA_BUF_ADDR_FIFO2_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO2, only used in Buffer Addr FIFO Mode. |
| 15:14          | /          | /           | /                                                                                                                                |
| 13:8           | RO         | 0x0         | CSIC_DMA_BUF_ADDR_FIFO1_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO1, only used in Buffer Addr FIFO Mode. |
| 7:6            | /          | /           | /                                                                                                                                |
| 5:0            | RO         | 0x0         | CSIC_DMA_BUF_ADDR_FIFO0_CONTENT<br>FIFO Content of address buffered in Buffer Address FIFO0, only used in Buffer Addr FIFO Mode. |

#### 6.1.8.31 0x0094 CSIC DMA Stored Frame Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: CSIC_DMA_STORED_FRM_CNT_REG                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                   |
| 7:0            | RO         | 0x0         | CSIC_DMA_STORED_FRM_CNT<br>Indicates value of stored frames counter. When the counter value reaches CSIC_DMA_STORED_FRM_THRESHOLD, the counter is cleared to 0. Only used in Buffer Addr FIFO Mode. |

#### 6.1.8.32 0x01F4 CSIC DMA Feature List Register(Default Value:0x0000\_0000)

| Offset: 0x01F4 |            |             | Register Name: CSIC_FEATURE_REG                            |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:2           | /          | /           | /                                                          |
| 1              | R          | 0x0         | DMA0_EMBEDDED_LBC<br>0: No Embedded LBC<br>1: Embedded LBC |
| 0              | R          | 0x0         | DMA0_EMBEDDED_FBC<br>0: No Embedded DMA<br>1: Embedded FBC |

## 6.2 TV Decoder

### 6.2.1 Overview

The Television Decoder (TVD) is an interface that transforms Composite Video Broadcast Signal (CVBS) or component signal into YUV data.

#### Features:

- 2-channel CVBS input and 1-channel CVBS decoder
- CVBS input, NTSC and PAL supported
- Supports YUV422, YUV420 format
- With 1 channel 3D comb filter
- Detection for signal locked and 625 lines
- Programmable brightness, contrast, saturation
- 10-bit video ADCs

### 6.2.2 Block Diagram

Figure 6-8 shows a block diagram of the TVD.

**Figure 6-8 TVD Block Diagram**



### 6.2.3 Functional Description

#### 6.2.3.1 External Signals

Table 6-3 describes the external signals of TVD.

**Table 6-3 TVD External Signals**

| Port Name | Description                            | Type |
|-----------|----------------------------------------|------|
| TVIN0     | TV CVBS Input 0                        | AI   |
| TVIN1     | TV CVBS Input 1                        | AI   |
| TVIN-VRP  | TV CVBS ADC Positive Reference Voltage | P    |
| TVIN-VRN  | TV CVBS ADC Negative Reference Voltage | P    |
| VCC-TVIN  | TV CVBS ADC Power                      | P    |

#### 6.2.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| TVD_TOP     | 0x05C00000   |
| TVD0        | 0x05C01000   |

| Register Name  | Offset                | Description                       |
|----------------|-----------------------|-----------------------------------|
| TVD_TOP        |                       |                                   |
| TVD_TOP_MAP    | 0x0000                | TVD TOP MAP Register              |
| TVD_3D_CTL1    | 0x0008                | TVD 3D DMA CONTROL Register1      |
| TVD_3D_CTL2    | 0x000C                | TVD 3D DMA CONTROL Register2      |
| TVD_3D_CTL3    | 0x0010                | TVD 3D DMA CONTROL Register3      |
| TVD_3D_CTL4    | 0x0014                | TVD 3D DMA CONTROL Register4      |
| TVD_3D_CTL5    | 0x0018                | TVD 3D DMA CONTROL Register5      |
| TVD_TOP_CTL    | 0x0024+0x20*N (N=0~3) | TVD TOP CONTROL Register          |
| TVD_ADC_CTL    | 0x0028+0x20*N (N=0~3) | TVD ADC CONTROL Register          |
| TVD_ADC_CFG    | 0x002C+0x20*N (N=0~3) | TVD ADC CONFIGURATION Register    |
| TVD0           |                       |                                   |
| TVD_EN         | 0x0000                | TVD MODULE CONTROL Register       |
| TVD_MODE       | 0x0004                | TVD MODE CONTROL Register         |
| TVD_CLAMP_AGC1 | 0x0008                | TVD CLAMP & AGC CONTROL Register1 |
| TVD_CLAMP_AGC2 | 0x000C                | TVD CLAMP & AGC CONTROL Register2 |
| TVD_HLOCK1     | 0x0010                | TVD HLOCK CONTROL Register1       |
| TVD_HLOCK2     | 0x0014                | TVD HLOCK CONTROL Register2       |
| TVD_HLOCK3     | 0x0018                | TVD HLOCK CONTROL Register3       |
| TVD_HLOCK4     | 0x001C                | TVD HLOCK CONTROL Register4       |

| Register Name  | Offset | Description                        |
|----------------|--------|------------------------------------|
| TVD_HLOCK5     | 0x0020 | TVD HLOCK CONTROL Register5        |
| TVD_VLOCK1     | 0x0024 | TVD VLOCK CONTROL Register1        |
| TVD_VLOCK2     | 0x0028 | TVD VLOCK CONTROL Register2        |
| TVD_CLOCK1     | 0x0030 | TVD CHROMA LOCK CONTROL Register1  |
| TVD_CLOCK2     | 0x0034 | TVD CHROMA LOCK CONTROL Register2  |
| TVD_YC_SEP1    | 0x0040 | TVD YC SEPERATION CONROL Register1 |
| TVD_YC_SEP2    | 0x0044 | TVD YC SEPERATION CONROL Register2 |
| TVD_ENHANCE1   | 0x0050 | TVD ENHANCEMENT CONTROL Register1  |
| TVD_ENHANCE2   | 0x0054 | TVD ENHANCEMENT CONTROL Register2  |
| TVD_ENHANCE3   | 0x0058 | TVD ENHANCEMENT CONTROL Register3  |
| TVD_WB1        | 0x0060 | TVD WB DMA CONTROL Register1       |
| TVD_WB2        | 0x0064 | TVD WB DMA CONTROL Register2       |
| TVD_WB3        | 0x0068 | TVD WB DMA CONTROL Register3       |
| TVD_WB4        | 0x006C | TVD WB DMA CONTROL Register4       |
| TVD_IRQ_CTL    | 0x0080 | TVD DMA Interrupt Control Register |
| TVD_IRQ_STATUS | 0x0090 | TVD DMA Interrupt Status Register  |
| TVD_DEBUG1     | 0x0100 | TVD DEBUG CONTROL Register1        |
| TVD_STATUS1    | 0x0180 | TVD DEBUG STATUS Register1         |
| TVD_STATUS2    | 0x0184 | TVD DEBUG STATUS Register2         |
| TVD_STATUS3    | 0x0188 | TVD DEBUG STATUS Register3         |
| TVD_STATUS4    | 0x018C | TVD DEBUG STATUS Register4         |
| TVD_STATUS5    | 0x0190 | TVD DEBUG STATUS Register5         |
| TVD_STATUS6    | 0x0194 | TVD DEBUG STATUS Register6         |

## 6.2.5 Register Description

### 6.2.5.1 0x0000 TVD TOP MAP Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TVD_TOP_MAP                                      |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:5           | /          | /           | /                                                               |
| 4              | R/W        | 0x0         | TVIN_SEL<br>TVIN Select<br>0:TVINO<br>1:TVIN1                   |
| 3:2            | /          | /           | /                                                               |
| 1:0            | R/W        | 0x0         | TVD_ADC_MAP<br>TVD ADC Map<br>01: CVBS_MODE<br>Others: Reserved |

### 6.2.5.2 0x0008 TVD 3D DMA CONTROL Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TVD_3D_CTL1                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:6           | /          | /           | /                                                                                                    |
| 5:4            | R/W        | 0x0         | COMB_3D_SEL<br>Comb 3D Select<br>00: TVD0<br>Others: Reserved                                        |
| 3:2            | /          | /           | /                                                                                                    |
| 1              | R/W        | 0x0         | COMB_3D_EN<br>Comb 3D Enable<br>0: Disable<br>1: Enable                                              |
| 0              | R/W        | 0x0         | TVD_EN_3D_DMA<br>TVD Enable 3D DMA<br>0: Disable<br>1: Enable<br>Set 0x1 when enable 3D comb filter. |

#### 6.2.5.3 0x000C TVD 3D DMA CONTROL Register2 (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: TVD_3D_CTL2 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | R/W        | 0x0         | DRAM_TRIG<br>DRAM Trigger  |

#### 6.2.5.4 0x0010 TVD 3D DMA CONTROL Register3 (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: TVD_3D_CTL3        |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:0           | R/W        | 0x0         | COMB_3D_ADDR0<br>Comb 3D Address0 |

#### 6.2.5.5 0x0014 TVD 3D DMA CONTROL Register4 (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: TVD_3D_CTL4        |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:0           | R/W        | 0x0         | COMB_3D_ADDR1<br>Comb 3D Address1 |

#### 6.2.5.6 0x0018 TVD 3D DMA CONTROL Register5 (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: TVD_3D_CTL5   |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:0           | R/W        | 0x0         | COMB_3D_SIZE<br>Comb 3D Size |

### 6.2.5.7 0x0024+0x20\*N(N=0~3) TVD TOP CONTROL Register (Default Value: 0x0000\_0000)

| Offset: 0x0024+0x20*N(N=0~3) |            |             | Register Name: TVD_TOP_CTL                                              |
|------------------------------|------------|-------------|-------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                             |
| 31:25                        | /          | /           | /                                                                       |
| 24                           | R/W        | 0x0         | LPF_DIG_SEL<br>Low Pass Filter Digital Select<br>0: 6M<br>1: 8M         |
| 23:5                         | /          | /           | /                                                                       |
| 4                            | R/W        | 0x0         | LPF_DIG_EN<br>Low Pass Filter Digital Enable<br>0: Disable<br>1: Enable |
| 3:0                          | /          | /           | /                                                                       |

### 6.2.5.8 0x0028+0x20\*N(N=0~3) TVD ADC CONTROL Register (Default Value: 0x0000\_0000)

| Offset: 0x0028+0x20*N(N=0~3) |            |             | Register Name: TVD_ADC_CTL                                                          |
|------------------------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                         |
| 31:5                         | /          | /           | /                                                                                   |
| 4:3                          | R/W        | 0x0         | LPF_SEL<br>Low Pass Filter Select<br>00: 11M<br>01: 16M                             |
| 2                            | R/W        | 0x0         | LPF_EN<br>Low Pass Filter Enable<br>0: Disable LPF circuit<br>1: Enable LPF circuit |
| 1                            | R/W        | 0x0         | AFE_EN<br>AFE Enable<br>0: Disable AFE circuit<br>1: Enable AFE circuit             |
| 0                            | R/W        | 0x0         | ADC_EN<br>ADC Enable<br>0: Disable ADC circuit<br>1: Enable ADC circuit             |

### 6.2.5.9 0x002C+0x20\*N(N=0~3) TVD ADC CONFIGURATION Register (Default Value: 0x0000\_0000)

| Offset: 0x002C+0x20*N(N=0~3) |            |             | Register Name: TVD_ADC_CFG                                                                      |
|------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                     |
| 31                           | R/W        | 0x0         | ADC_TEST<br>ADC Test Mode Configuration<br>0: Normal mode<br>1: For ADC test                    |
| 30:29                        | /          | /           | /                                                                                               |
| 28                           | R/W        | 0x0         | DATA_DLY<br>Data Delay Configuration<br>0: No delay<br>1: Delay ADC output data for half circle |
| 27:19                        | /          | /           | /                                                                                               |
| 18:16                        | R/W        | 0x0         | CLP_STEP<br>CLAMP Step Configuration<br>DC level size step for up and down.                     |
| 15:14                        | R/W        | 0x0         | STAGE8_IBIAS<br>Stage8 Ibias Configuration                                                      |
| 13:12                        | R/W        | 0x0         | STAGE7_IBIAS<br>Stage7 Ibias Configuration                                                      |
| 11:10                        | R/W        | 0x0         | STAGE6_IBIAS<br>Stage6 Ibias Configuration                                                      |
| 9:8                          | R/W        | 0x0         | STAGE5_IBIAS<br>Stage5 Ibias Configuration                                                      |
| 7:6                          | R/W        | 0x0         | STAGE4_IBIAS<br>Stage4 Ibias Configuration                                                      |
| 5:4                          | R/W        | 0x0         | STAGE3_IBIAS<br>Stage3 Ibias Configuration                                                      |
| 3:2                          | R/W        | 0x0         | STAGE2_IBIAS<br>Stage2 Ibias Configuration                                                      |
| 1:0                          | R/W        | 0x0         | STAGE1_IBIAS<br>Stage1 Ibias Configuration                                                      |

### 6.2.5.10 0x0000 TVD MODULE CONTROL Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TVD_EN                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:27          | /          | /           | /                                                                                                          |
| 26             | R/W        | 0x0         | EN_LOCK_DISABLE_WB2<br>Enable Lock Disable WB2                                                             |
| 25             | R/W        | 0x0         | EN_LOCK_DISABLE_WB1<br>Enable Lock Disable WB1                                                             |
| 24:16          | /          | /           | /                                                                                                          |
| 15             | R/W        | 0x0         | CLR_RSMP_FIFO<br>Clear Resample FIFO<br>0: Release<br>1: Clear<br>Set 0x1 then 0x0 to reset resample FIFO. |
| 14:1           | /          | /           | /                                                                                                          |
| 0              | R/W        | 0x0         | TVD_EN_CH<br>TVD Enable CH<br>0: Disable<br>1: Enable                                                      |

## 6.2.5.11 0x0004 TVD MODE CONTROL Register (Default Value: 0x0000\_0020)

| Offset: 0x0004 |            |             | Register Name: TVD_MODE                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:9           | /          | /           | /                                                                                                     |
| 8              | R/W        | 0x0         | BLUE_MODE_COLOR<br>Blue Mode Color<br>0: Blue<br>1: Black                                             |
| 7:6            | /          | /           | /                                                                                                     |
| 5:4            | R/W        | 0x2         | BLUE_DISPLAY_MODE<br>Blue Display Mode<br>00 : Disabled<br>01 : Enabled<br>10 : Auto<br>11 : Reserved |
| 3              | /          | /           | /                                                                                                     |
| 2              | R/W        | 0x0         | PROGRESSIVE_MODE<br>Progressive Mode<br>0: Interlace mode<br>1: Progressive mode                      |
| 1              | R/W        | 0x0         | SVIDEO_MODE<br>Svideo Mode<br>0 : CVBS<br>1 : S-Video                                                 |
| 0              | R/W        | 0x0         | YPBPR_MODE<br>Ypbpr Mode<br>0 : Disable the component input<br>1 : Enable the component input         |

## 6.2.5.12 0x0008 TVD CLAMP &amp; AGC CONTROL Register1 (Default Value: 0xA01\_DD02)

| Offset: 0x0008 |            |             | Register Name: TVD_CLAMP_AGC1                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                  |
| 31:24          | R/W        | 0xA0        | CAGC_TARGET<br>Cagc Target<br>These bits set the chroma AGC target                                                                                                                                                                           |
| 23:17          | /          | /           | /                                                                                                                                                                                                                                            |
| 16             | R/W        | 0x1         | CAGC_EN<br>Cagc Enable<br>0 : OFF<br>1 : ON                                                                                                                                                                                                  |
| 15:8           | R/W        | 0xDD        | AGC_TARGET<br>Auto Gain Control Target<br>When AGC_EN = 1 , the AGC_TARGET is used to directly digital AGC circuit.<br>When AGC_EN = 0 , the AGC_TARGET is used to directly drive the analog PGA.<br>(64 represents 1x, 32 represents 0.5x). |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                            |
| 1              | R/W        | 0x1         | AGC_FREQUENCE<br>Auto Gain Control Freqence<br>0 : AGC gain update once per line<br>1 : AGC gain update once per frame                                                                                                                       |
| 0              | R/W        | 0x0         | AGC_EN<br>Auto Gain Control Enable<br>0 : AGC disable<br>1 : AGC enable                                                                                                                                                                      |

#### 6.2.5.13 0x000C TVD CLAMP & AGC CONTROL Register2 (Default Value: 0x8682\_6440)

| Offset: 0x000C |            |             | Register Name: TVD_CLAMP_AGC2                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31             | R/W        | 0x1         | BLACK_LVL_CLP<br>Black Level Clamp<br>0: subtraction 0<br>1: subtraction 16        |
| 30:29          | /          | /           | /                                                                                  |
| 28:16          | R/W        | 0x682       | AGC_GATE_BEGIN<br>AGC Gate Begin<br>Count from hsync to the next line AGC gate     |
| 15:8           | R/W        | 0x64        | AGC_BACKPORCH_DLY<br>AGC Backporch Delay<br>Count from sync tip to back porch gate |
| 7              | /          | /           | /                                                                                  |
| 6:0            | R/W        | 0x40        | AGC_GATE_WIDTH<br>AGC Gate Width                                                   |

#### 6.2.5.14 0x0010 TVD HLOCK CONTROL Register1 (Default Value: 0x2000\_0000)

| Offset: 0x0010 |            |             | Register Name: TVD_HLOCK1                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:0           | R/W        | 0x20000000  | H_SAMPLE_STEP<br>H Sample Step<br>$H\_SAMPLE\_STEP = Fout/Fin \times 2^{30}$ |

### 6.2.5.15 0x0014 TVD HLOCK CONTROL Register2 (Default Value: 0x4ED6\_0000)

| Offset: 0x0014 |            |             | Register Name: TVD_HLOCK2                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31:24          | R/W        | 0x4E        | HS_FILTER_GATE_END_TIME<br>HSYNC Filter Gate End Time<br>These bits specify the end of the horizontal-blank-interval window.<br>Default/Hex = 78            |
| 23:16          | R/W        | 0xD6        | HS_FILTER_GATE_START_TIME<br>HSYNC Filter Gate Start Time<br>These bits specify the beginning of the horizontal-blank-interval window.<br>Default/Hex = -42 |
| 15:4           | /          | /           | /                                                                                                                                                           |
| 3:0            | R/W        | 0x0         | HTOL<br>Horizontal Total Pixels Per Line<br>0: 858<br>1: 864<br>2~7: Reserved                                                                               |

### 6.2.5.16 0x0018 TVD HLOCK CONTROL Register3 (Default Value: 0x0FE9\_502D)

| Offset: 0x0018 |            |             | Register Name: TVD_HLOCK3                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:24          | R/W        | 0x0F        | HS_TIP_DET_WIN_END_TIME<br>HSYNC Tip Detect Window End Time                 |
| 23:16          | R/W        | 0xE9        | HS_TIP_DET_WIN_START_TIME<br>HSYNC Tip Detect Window Start Time             |
| 15:8           | R/W        | 0x50        | HS_RISING_DET_WIN_END_TIME<br>HSYNC Rising Detect Window End Time           |
| 7:0            | R/W        | 0x2D        | HS_RISING_DETECT_WINDOW_START_TIME<br>HSYNC Rising Detect Window Start Time |

#### 6.2.5.17 0x001C TVD HLOCK CONTROL Register4 (Default Value: 0x3E3E\_8000)

| Offset: 0x001C |            |             | Register Name: TVD_HLOCK4                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:24          | R/W        | 0x3E        | HS_FINE_TO_COARSE_OFFSET<br>HSYNC Fine To Coarse Offset                                  |
| 23:16          | R/W        | 0x3E        | HS_RISING_TIME_FOR_FINE_DET<br>HSYNC Rising Time For Fine Detect                         |
| 15:8           | R/W        | 0x80        | HS_DET_WIN_END_TIME_FOR_COARSE_DET<br>HSYNC Detect Window End Time For Corase Detect     |
| 7:0            | R/W        | 0x00        | HS_DET_WIN_START_TIME_FOR_COARSE_DET<br>HSYNC Detect Window Start Time For Coarse Detect |

#### 6.2.5.18 0x0020 TVD HLOCK CONTROL Register5 (Default Value: 0x4E22\_5082)

| Offset: 0x0020 |            |             | Register Name: TVD_HLOCK5                                          |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:24          | R/W        | 0x4E        | BACKPORCH_DET_WIN_END_TIME<br>Backporch Detect Window End Time     |
| 23:16          | R/W        | 0x22        | BACKPORCH_DET_WIN_START_TIME<br>Backporch Detect Window Start Time |
| 15:8           | R/W        | 0x50        | HACT_WIDTH<br>Hactive Width                                        |
| 7:0            | R/W        | 0x82        | HACT_START<br>Hactive Start                                        |

**6.2.5.19 0x0024 TVD VLOCK CONTROL Register1 (Default Value: 0x0061\_0220)**

| Offset: 0x0024 |            |             | Register Name: TVD_VLOCK1                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:27          | /          | /           | /                                                                     |
| 26:16          | R/W        | 0x61        | VACT_HEIGHT<br>Vactive Height                                         |
| 15             | /          | /           | /                                                                     |
| 14:4           | R/W        | 0x22        | VACTIVE_START<br>VACT START                                           |
| 3              | /          | /           | /                                                                     |
| 2:0            | R/W        | 0x0         | VTOL<br>Vertical Total Line Per Frame<br>0 : 525 line<br>1 : 625 line |

**6.2.5.20 0x0028 TVD VLOCK CONTROL Register2 (Default Value: 0x000E\_0070)**

| Offset: 0x0028 |            |             | Register Name: TVD_VLOCK2                                       |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:21          | /          | /           | /                                                               |
| 20:16          | R/W        | 0xE         | HS_DET_DISABLE_END_LINE<br>Hsync Detector Disable End Line      |
| 15:7           | /          | /           | /                                                               |
| 6:0            | R/W        | 0x70        | HS_DET_DISABLE_START_LINE<br>Hsync Dectector Disable Start Line |

## 6.2.5.21 0x0030 TVD CHROMA LOCK CONTROL Register1 (Default Value: 0x0046\_3201)

| Offset: 0x0030 |            |             | Register Name: TVD_CLOCK1                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:29          | /          | /           | /                                                                                                                 |
| 28             | R/W        | 0x0         | COLOR_STD_NTSC<br>Color Standard Ntsc<br>0: NTSC358<br>1: NTSC443<br>Only valid when COLOR_STD set as NTSC        |
| 27:26          | R/W        | 0x0         | CHROMA_LPF<br>CHROMA Low Pass Filter<br>00: Narrow<br>01: Middle<br>10: Wide<br>11: Reserved                      |
| 25             | /          | /           | /                                                                                                                 |
| 24             | R/W        | 0x0         | WIDE_BURST_GATE<br>Wide Burst_Gate<br>0: Narrow burst gate<br>1: Wide burst gate                                  |
| 23:16          | R/W        | 0x46        | BURST_GATE_END_TIME<br>Burst Gate End Time                                                                        |
| 15:8           | R/W        | 0x32        | BURST_GATE_START_TIME<br>Burst Gate Start Time                                                                    |
| 7:4            | /          | /           | /                                                                                                                 |
| 3:1            | R/W        | 0x0         | COLOR_STD<br>COLOR Standard<br>000: NTSC<br>001: PAL (I,B,G,H,D,N)<br>010: PAL (M)<br>011: PAL (CN)<br>100: SECAM |
| 0              | R/W        | 0x1         | COLOR_KILLER_EN<br>Color Killer Enable<br>1: Disable color when chroma unlock                                     |

### 6.2.5.22 0x0034 TVD CHROMA LOCK CONTROL Register2 (Default Value: 0x21F0\_7C1F)

| Offset: 0x0034 |            |             | Register Name: TVD_CLOCK2                                        |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:0           | R/W        | 0x21F07C1F  | C_SAMPLE_STEP<br>C Sample Step<br>C_SAMPLE_STEP = Fsc/Fin X 2^30 |

### 6.2.5.23 0x0040 TVD YC SEPERATION CONROL Register1 (Default Value: 0x0000\_4209)

| Offset: 0x0040 |            |             | Register Name: TVD_YC_SEP1                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:30          | /          | /           | /                                                                                          |
| 29             | R/W        | 0x0         | CHROMA_CORING_EN<br>Chroma Coring Enable                                                   |
| 28:26          | R/W        | 0x0         | 3D_COMB_FACTOR<br>3D Comb Factor                                                           |
| 25:23          | R/W        | 0x0         | 2D_COMB_FACTOR<br>2D Comb Factor                                                           |
| 22:20          | R/W        | 0x0         | NOTCH_FACTOR<br>Notch Factor                                                               |
| 19:17          | /          | /           | /                                                                                          |
| 16             | R/W        | 0x0         | COMB_FILTER_BUF_CLR<br>Comb Filter Buffer Clear<br>0: Not clear<br>1: Clear                |
| 15:10          | R/W        | 0x10        | PAL_CHROMA_LVL<br>PAL Chroma Level<br>Chroma level threshold for chroma comb filter select |
| 9              | R/W        | 0x1         | CHROMA_BANDPASS_FILTER_EN<br>Chroma Bandpass Filter Enable<br>0: Disable<br>1: Enable      |
| 8              | R/W        | 0x0         | SECAM_NOTCH_WIDE<br>Notch bandwidth<br>0: Narrow<br>1 : Wide                               |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                    |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4 | R/W | 0x0 | 2D_COMB_FILTER_MODE<br>2D Comb Filter Mode<br>For NTSC:<br>0000: 2D comb<br>0001~0010: Reserved<br>0011: 1D comb<br>0100~1000: Reserved<br>For PAL:<br>0000: 2D comb filter1<br>0001: 1D comb filter1<br>0010: 2D comb filter2<br>0011: 1D comb filter2<br>0100: 1D comb filter3<br>0101: Reserved<br>0110: 2D comb filter3<br>0111~1000: Reserved |
| 3   | R/W | 0x1 | 3D_COMB_FILTER_DIS<br>3D Comb Filter Disable<br>0: Enable 3D comb filter<br>1: Disable 3D comb filter                                                                                                                                                                                                                                              |
| 2:0 | R/W | 0x1 | 3D_COMB_FILTER_MODE<br>3D Comb_Filter Mode<br>000: 2D mode<br>001: 3D YC separation mode1<br>010~011: reserved<br>0100: 3D YC separation mode2                                                                                                                                                                                                     |

## 6.2.5.24 0x0044 TVD YC SEPERATION CONROL Register2 (Default Value: 0xFF64\_40AF)

| Offset: 0x0044 |            |             | Register Name: TVD_YC_SEP2                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:30          | R/W        | 0x3         | V_NOISE_FACTOR<br>Vertical Noise Factor                      |
| 29:28          | R/W        | 0x3         | BURST_NOISE_FACTOR<br>Burst Noise Factor                     |
| 27:26          | R/W        | 0x3         | CHROMA_NOISE_FACTOR<br>Chroma Noise Factor                   |
| 25:24          | R/W        | 0x3         | LUMA_NOISE_FACTOR<br>Luma Noise Factor                       |
| 23:17          | R/W        | 0x32        | NOISE_THRESHOLD<br>Noise Threshold                           |
| 16             | R/W        | 0x0         | NOISE_DET_EN<br>Noise Detect Enable                          |
| 15:9           | R/W        | 0x20        | MOTION_DET_NOISE_THRESHOLD<br>Motion Detect Noise Threshold  |
| 8              | R/W        | 0x0         | MOTION_DET_NOISE_DET_EN<br>Motion Detect Noise Detect Enable |
| 7:6            | R/W        | 0x2         | CHROMA_V_FILTER_GAIN<br>Chroma Vertical Filter Gain          |
| 5:4            | R/W        | 0x2         | LUMA_V_FILTER_GAIN<br>Luma Vertical Filter Gain              |
| 3:2            | R/W        | 0x3         | H_CHROMA_FILTER_GAIN<br>Horizontal Chroma Filter Gain        |
| 1:0            | R/W        | 0x3         | H_LUMA_FILTER_GAIN<br>Horizontal Luma Filter Gain            |

### 6.2.5.25 0x0050 TVD ENHANCEMENT CONTROL Register1 (Default Value: 0x1420\_8000)

| Offset: 0x0050 |            |             | Register Name: TVD_ENHANCE1                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                 |
| 29:28          | R/W        | 0x1         | SHARP_COEF2<br>Sharp Coef2                                                                                                                        |
| 27:25          | R/W        | 0x2         | SHARP_COEF1<br>Sharp Coef1<br>$Ysharp = Y + YH * (SHARP_COEF1 / SHARP_COEF2)$                                                                     |
| 24             | R/W        | 0x0         | SHARP_EN<br>Sharp Enable<br>0: Disable<br>1: Enable                                                                                               |
| 23:16          | R/W        | 0x20        | BRIGHT_OFFSET<br>Bright Offset<br>Set 0x00, brightness offset is -32;<br>Set 0x20, brightness offset is 0.<br>Set 0xFF, brightness offset is max. |
| 15:8           | R/W        | 0x80        | CONTRAST_GAIN<br>Contrast Gain<br>Set 0x00, contrast gain is min.<br>Set 0x80, contrast gain is 1.<br>Set 0xFF, contrast gain is max.             |
| 7:4            | /          | /           | /                                                                                                                                                 |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0 | R/W | 0x0 | <p>YC_DLY<br/>YC Delay</p> <p>0000: Y and C no delay<br/>0001: Y delay 1 cycle to C<br/>0010: Y delay 2 cycle to C<br/>0011: Y delay 3 cycle to C<br/>0100: Y delay 4 cycle to C<br/>0101: Y delay 5 cycle to C<br/>0110: Y delay 6 cycle to C<br/>0111: Y delay 7 cycle to C<br/>1000: Reserved<br/>1001: Reserved<br/>1010: Reserved<br/>1011: C delay 5 cycle to Y<br/>1100: C delay 4 cycle to Y<br/>1101: C delay 3 cycle to Y<br/>1110: C delay 2 cycle to Y<br/>1111: C delay 1 cycle to Y</p> |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 6.2.5.26 0x0054 TVD ENHANCEMENT CONTROL Register2 (Default Value: 0x0000\_0680)

| Offset: 0x0054 |            |             | Register Name: TVD_ENHANCE2                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 31:11          | /          | /           | /                                                                                                                                                |
| 10:9           | R/W        | 0x3         | CHROMA_ENHANCE_STRENGTH<br>Chroma Enhance Strength<br>00: Mild<br>01: Low<br>10: Middle<br>11: High                                              |
| 8              | R/W        | 0x0         | CHROMA_ENHANCE_EN<br>Chroma Enhance Enable<br>0: Disable<br>1: Enable                                                                            |
| 7:0            | R/W        | 0x80        | SATURATION_GAIN<br>Saturation Gain<br>Set 0x00, saturation gain is min ;<br>Set 0x80, saturation gain is 1.<br>Set 0xFF, saturation gain is max. |

#### 6.2.5.27 0x0058 TVD ENHANCEMENT CONTROL Register3 (Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: TVD_ENHANCE3        |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:29          | /          | /           | /                                  |
| 28             | R/W        | 0x0         | CB_CR_GAIN_EN<br>Cb Cr Gain Enable |
| 27:16          | R/W        | 0x0         | CR_GAIN<br>Cr Gain                 |
| 15:12          | /          | /           | /                                  |
| 11:0           | R/W        | 0x00        | CB_GAIN<br>Cb Gain                 |

**6.2.5.28 0x0060 TVD WB DMA CONTROL Register1 (Default Value: 0x02D0\_0020)**

| Offset: 0x0060 |            |             | Register Name: TVD_WB1                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31             | R/W        | 0x0         | UV_SEQ<br>UV Sequence<br>0: UVUV<br>1: VUVU                                                                                                                        |
| 30:29          | /          | /           | /                                                                                                                                                                  |
| 28             | R/W        | 0x0         | YUV420_FILTER_EN<br>YUV420 Filter Enable<br>0: disable YUV420 WB data from YUV422 without chroma filter<br>1: enable YUV420 WB data from YUV422 with chroma filter |
| 27:16          | R/W        | 0x2D0       | HACT_STRIDE<br>Hactive Stride<br>Horizontal active line stride                                                                                                     |
| 15:9           | /          | /           | /                                                                                                                                                                  |
| 8              | R/W        | 0x0         | WB_ADDR_VALID<br>WB Address Valid<br>0: Invalid<br>1: Valid                                                                                                        |
| 7              | /          | /           | /                                                                                                                                                                  |
| 6              | R/W        | 0x0         | FLIP_FIELD<br>Flip Field<br>This bit flips even/odd fields                                                                                                         |
| 5              | R/W        | 0x1         | WB_FRAME_MODE<br>WB Frame Mode<br>0: Odd field or even field (decided by bit2)<br>1: Frame                                                                         |
| 4              | R/W        | 0x0         | WB_MB_MODE<br>WB MB Mode<br>0: Planar mode<br>1: Mb mode                                                                                                           |
| 3              | R/W        | 0x0         | HYSCALE_EN<br>Hyscale_Enable                                                                                                                                       |
| 2              | R/W        | 0x0         | FIELD_SEL<br>Field_Select<br>0: field 0 only<br>1: filed 1 only                                                                                                    |

|   |     |     |                                               |
|---|-----|-----|-----------------------------------------------|
| 1 | R/W | 0x0 | WB_FMT<br>WB Format<br>0: YUV420<br>1: YUV422 |
| 0 | R/W | 0x0 | WB_EN<br>WB Enable<br>0: Disable<br>1: Enable |

#### 6.2.5.29 0x0064 TVD WB DMA CONTROL Register2 (Default Value: 0x00F0\_02D0)

| Offset: 0x0064 |            |             | Register Name: TVD_WB2                     |
|----------------|------------|-------------|--------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                |
| 31:27          | /          | /           | /                                          |
| 26:16          | R/W        | 0xF0        | VACT_NUM<br>Vertical active line number    |
| 15:12          | /          | /           | /                                          |
| 11:0           | R/W        | 0x2D0       | HACT_NUM<br>Horizontal active pixel number |

#### 6.2.5.30 0x0068 TVD WB DMA CONTROL Register3 (Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: TVD_WB3      |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:0           | R/W        | 0x0         | CH1_Y_ADDR<br>Ch1 Y Address |

#### 6.2.5.31 0x006C TVD WB DMA CONTROL Register4 (Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: TVD_WB4      |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:0           | R/W        | 0x0         | CH1_C_ADDR<br>Ch1 C Address |

### 6.2.5.32 0x0080 TVD DMA Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: TVD_IRQ_CTL                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31             | R/W        | 0x0         | FIFO_3D_TX_O_EN<br>FIFO 3D TX Overflow Enable<br>0: IRQ disable<br>1: IRQ enable  |
| 30             | R/W        | 0x0         | FIFO_3D_TX_U_EN<br>FIFO 3D TX Underflow Enable<br>0: IRQ disable<br>1: IRQ enable |
| 29             | R/W        | 0x0         | FIFO_3D_RX_O_EN<br>FIFO 3D RX Overflow ENable<br>0: IRQ disable<br>1: IRQ enable  |
| 28             | R/W        | 0x0         | FIFO_3D_RX_U_EN<br>FIFO 3D RX Underflow Enable<br>0: IRQ disable<br>1: IRQ enable |
| 27:25          | /          | /           | /                                                                                 |
| 24             | R/W        | 0x0         | FRAME_END_EN<br>Frame End Enable<br>0: IRQ disable<br>1: IRQ enable               |
| 23:9           | /          | /           | /                                                                                 |
| 8              | R/W        | 0x0         | FIFO_Y_U_EN<br>FIFO Y Underflow Enable<br>0: IRQ disable<br>1: IRQ enable         |
| 7              | R/W        | 0x0         | FIFO_PB_U_EN<br>FIFO PB Underflow ENable<br>0: IRQ disable<br>1: IRQ enable       |
| 6              | R/W        | 0x0         | FIFO_PR_U_EN<br>FIFO PR Underflow Enable<br>0: IRQ disable<br>1: IRQ enable       |

|   |     |     |                                                                            |
|---|-----|-----|----------------------------------------------------------------------------|
| 5 | R/W | 0x0 | FIFO_Y_O_EN<br>FIFO Y Overflow Enable<br>0: IRQ disable<br>1: IRQ enable   |
| 4 | R/W | 0x0 | FIFO_PB_O_EN<br>FIFO PB Overflow Enable<br>0: IRQ disable<br>1: IRQ enable |
| 3 | R/W | 0x0 | FIFO_PR_O_EN<br>FIFO PR Overflow Enable<br>0: IRQ disable<br>1: IRQ enable |
| 2 | /   | /   | /                                                                          |
| 1 | R/W | 0x0 | UNLOCK_EN<br>Unlock Enable<br>0: IRQ disable<br>1: IRQ enable              |
| 0 | R/W | 0x0 | LOCK_EN<br>Lock Enable<br>0: IRQ disable<br>1: IRQ enable                  |

### 6.2.5.33 0x0090 TVD DMA Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: TVD_IRQ_STATUS                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31             | R/W        | 0x0         | FIFO_3D_TX_O<br>FIFO 3D TX Overflow<br>0: FIFO work normal<br>1: FIFO overflow<br>Write 0x1 to clear this bit.   |
| 30             | R/W        | 0x0         | FIFO_3D_TX_U<br>FIFO 3D TX Underflow<br>0: FIFO work normal<br>1: FIFO underflow<br>Write 0x1 to clear this bit. |
| 29             | R/W        | 0x0         | FIFO_3D_RX_O<br>FIFO 3D RX Overflow<br>0: FIFO work normal<br>1: FIFO overflow<br>Write 0x1 to clear this bit.   |
| 28             | R/W        | 0x0         | FIFO_3D_RX_U<br>FIFO 3D RX Underflow<br>0: FIFO work normal<br>1: FIFO underflow<br>Write 0x1 to clear this bit. |
| 27:25          | /          | /           | /                                                                                                                |
| 24             | R/W        | 0x0         | FRAME_END<br>Frame End<br>This bit is auto set every write back frame. Set 0x1 to clear this bit.                |
| 23:17          | /          | /           |                                                                                                                  |
| 16             | R/W        | 0x0         | WB_ADDR_CHANGE_ERR<br>WB Address Change_Error<br>Write back address change error                                 |
| 15:9           | /          | /           | /                                                                                                                |
| 8              | R/W        | 0x0         | FIFO_Y_U<br>FIFO Y Underflow<br>0: FIFO work normal<br>1: FIFO underflow<br>Write 0x1 to clear this bit.         |

|     |     |     |                                                                                                          |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------|
| 7   | R/W | 0x0 | FIFO_C_U<br>FIFO C Underflow<br>0: FIFO work normal<br>1: FIFO underflow<br>Write 0x1 to clear this bit. |
| 6   | /   | /   | /                                                                                                        |
| 5   | R/W | 0x0 | FIFO_Y_O<br>FIFO Y Overflow<br>0: FIFO work normal<br>1: FIFO overflow<br>Write 0x1 to clear this bit.   |
| 4   | R/W | 0x0 | FIFO_C_O<br>FIFO C Overflow<br>0: FIFO work normal<br>1: FIFO overflow<br>Write 0x1 to clear this bit.   |
| 3:2 | /   | /   | /                                                                                                        |
| 1   | R/W | 0x0 | UNLOCK<br>Unlock<br>0: TVD status no change<br>1: TVD status change from lock to unlock                  |
| 0   | R/W | 0x0 | LOCK<br>Lock<br>0: TVD status no change<br>1: TVD status change from unlock to lock                      |

## 6.2.5.34 0x0100 TVD DEBUG CONTROL Register1 (Default Value: 0x0010\_0000)

| Offset: 0x0100 |            |             | Register Name: TVD_DEBUG1                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:25          | R/W        | 0x0         | CLAMP_UPDN_CYCLES<br>Clamp Updn Cycles                                                                                                                                            |
| 24             | R/W        | 0x0         | CLAMP_DN_START<br>Clamp Dn Start<br>Write 0x1 to make clamp up, clamp up value is determine by CLAMP_UPDN_CYCLES. Note that this bit is only valid when CLAMP_MODE is set as 0x1. |
| 23             | R/W        | 0x0         | CLAMP_UP_START<br>Clamp Up Start<br>Write 0x1 to make clamp up, clamp up value is determine by CLAMP_UPDN_CYCLES. Note that this bit is only valid when CLAMP_MODE is set as 0x1. |
| 22             | R/W        | 0x0         | CLAMP_MODE<br>Clamp Mode<br>0: Normal, auto clamp control<br>1: Debug mode, clamp control by register                                                                             |
| 21             | R/W        | 0x0         | AFE_GAIN_MODE<br>Afe Gain Mode<br>0: Auto gain mode<br>1: Debug mode, AFE gain is determine by AFE_GAIN_VALUE                                                                     |
| 20             | R/W        | 0x1         | UNLOCK_RST_GAIN_EN<br>Unlock Reset Gain Enable                                                                                                                                    |
| 19             | R/W        | 0x0         | TRUNCATION_RST_GAIN_EN<br>Truncation Reset Gain Enable                                                                                                                            |
| 18             | R/W        | 0x0         | TRUNCATION2_RST_GAIN_EN<br>Truncation2 Reset Gain Enable                                                                                                                          |
| 17             | R/W        | 0x0         | TVIN_LOCK_HIGH<br>TVIN Lock High                                                                                                                                                  |
| 16             | R/W        | 0x0         | TVIN_LOCK_DEBUG<br>TVIN Lock Debug                                                                                                                                                |
| 15:8           | R/W        | 0x0         | AFE_GAIN_VALUE<br>AFE Gain Value                                                                                                                                                  |
| 7:0            | /          | /           | /                                                                                                                                                                                 |

#### 6.2.5.35 0x0180 TVD DEBUG STATUS Register1 (Default Value: 0x0000\_0020)

| Offset: 0x0180 |            |             | Register Name: TVD_STATUS1                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:24          | /          | /           | /                                                                         |
| 23:16          | R          | 0x0         | CHROMA_MAGNITUDE_STATUS<br>These bits contain the chroma magnitude.       |
| 15:8           | R          | 0x0         | AGC_DIGITAL_GAIN_STATUS<br>These bits contain the digital AGC gain value. |
| 7:0            | R          | 0x20        | AGC_ANALOG_GAIN_STATUS<br>These bits contain the analog AGC gain value.   |

#### 6.2.5.36 0x0184 TVD DEBUG STATUS Register2 (Default Value: 0x21F0\_7C1F)

| Offset: 0x0184 |            |             | Register Name: TVD_STATUS2 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | R          | 0x21f07c1f  | CHROMA_SYNC.DTO_STATUS     |

#### 6.2.5.37 0x0188 TVD DEBUG STATUS Register3 (Default Value: 0x2000\_0000)

| Offset: 0x0188 |            |             | Register Name: TVD_STATUS3                   |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:30          | /          | /           | /                                            |
| 29:0           | R          | 0x20000000  | H_SYNC.DTO_STS<br>Horizontal Sync Dto Status |

### 6.2.5.38 0x018C TVD DEBUG STATUS Register4 (Default Value: 0x0000\_0001)

| Offset: 0x018C |            |             | Register Name: TVD_STATUS4                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                      |
| 31:24          | /          | /           | /                                                                                                                                                                                |
| 23             | R          | 0x0         | VCR_REW<br>VCR Rewind Detected                                                                                                                                                   |
| 22             | R          | 0x0         | VCR_FF<br>VCR Fast-Forward Detected                                                                                                                                              |
| 21             | R          | 0x0         | VCR_TRICK<br>VCR Trick-Mode Detected                                                                                                                                             |
| 20             | R          | 0x0         | VCR<br>VCR Detected                                                                                                                                                              |
| 19             | R          | 0x0         | NOISY<br>Noisy Signal Detected. This bit is set when the detected noise value (status register 7Fh) is greater than the value programmed into the "noise_thresh" register (05h). |
| 18             | R          | 0x0         | DET_625_LINE<br>Detect 625 Line<br>0: 525 lines<br>1: 625 lines                                                                                                                  |
| 17             | R          | 0x0         | SECAM_DET<br>SECAM Colour Mode Detected                                                                                                                                          |
| 16             | R          | 0x0         | PAL_DET<br>PAL Colour Mode Detected                                                                                                                                              |
| 15:11          | /          | /           | /                                                                                                                                                                                |
| 10             | R          | 0x0         | VNON_STANDARD<br>Vertical Frequency Non-Standard Input Signal Detected                                                                                                           |
| 9              | R          | 0x0         | HNON_STANDARD<br>Horizontal Frequency Non-Standard Input Signal Detected                                                                                                         |
| 8              | R          | 0x0         | PROSCAN_DET<br>Progressive Scan Detected                                                                                                                                         |
| 7:5            | R          | 0x0         | MACROVISION_COLOR_STRIPES_DET<br>The Number Indicates The Number Of Color Stripe lines in each group                                                                             |
| 4              | R          | 0x0         | MACROVISION_VBI_PSEUDO_SYNC_PULSES_DET<br>Macrovision Vbi Pseudo Sync Pulses Detect<br>0: Undetected<br>1: Detected                                                              |

|   |   |     |                                                                                                |
|---|---|-----|------------------------------------------------------------------------------------------------|
| 3 | R | 0x0 | CHROMA_PLL_LOCKED_TO_COLOR_BURST<br>Chroma PII Locked To Color Burst<br>0: Unlock<br>1: Locked |
| 2 | R | 0x0 | V_LOCK<br>Vertical Lock<br>0: Unlock<br>1: Locked                                              |
| 1 | R | 0x0 | H_LINE_LOCK<br>Horizontal line locked<br>0: Unlock<br>1: Locked                                |
| 0 | R | 0x1 | NO_SIG_DET<br>No Signal Detected<br>0 : Signal Detected<br>1 : No Signal Detected              |

#### 6.2.5.39 0x0190 TVD DEBUG STATUS Register5 (Default Value: 0x0000\_0000)

| Offset: 0x0190 |            |             | Register Name: TVD_STATUS5    |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:22          | R          | 0x0         | BLK_LVL<br>Blank Level        |
| 21:12          | R          | 0x0         | SYNC_LVL<br>Sync Level        |
| 11             | R/W        | 0x0         | ADC_DAT_SH<br>ADC Data Show   |
| 10             | /          | /           | /                             |
| 9:0            | R          | 0x0         | ADC_DAT_VAL<br>ADC Data Value |

## 6.2.5.40 0x0194 TVD DEBUG STATUS Register6 (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: TVD_STATUS6                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31:11          | /          | /           | /                                                                                                                                                       |
| 10             | R/W        | 0x0         | MASK_UNKNOWN<br>Mask Unknown                                                                                                                            |
| 9              | R/W        | 0x0         | MASK_SECAM<br>Mask Secam                                                                                                                                |
| 8              | R/W        | 0x0         | MASK_NTSC443<br>Mask NTSC443                                                                                                                            |
| 7              | R/W        | 0x0         | MASK_PAL60<br>Mask PAL60                                                                                                                                |
| 6              | R/W        | 0x0         | MASK_PALCN<br>Mask Palcn                                                                                                                                |
| 5              | R/W        | 0x0         | MASK_PALM<br>Mask Palm                                                                                                                                  |
| 4              | R/W        | 0x0         | AUTO_DET_EN<br>Auto Detect Enable<br>0: Disable<br>1: Enable                                                                                            |
| 3:1            | R          | 0x0         | TV_STD<br>TV Standard<br>001: V525_NTSC<br>010: V625_PAL<br>011: V525_PALM<br>100: V625_PALN<br>101: V525_PAL60<br>110: V525_NTSC443<br>111: V625_SECAM |
| 0              | R          | 0x0         | AUTO_DET_FINISH<br>Auto Detect Finish                                                                                                                   |

## Contents

|       |                                     |     |
|-------|-------------------------------------|-----|
| 7     | Memory.....                         | 621 |
| 7.1   | SDRAM Controller (DRAMC) .....      | 621 |
| 7.2   | SD/MMC Host Controller (SMHC) ..... | 622 |
| 7.2.1 | Overview .....                      | 622 |
| 7.2.2 | Block Diagram .....                 | 622 |
| 7.2.3 | Functional Description .....        | 623 |
| 7.2.4 | Programming Guidelines.....         | 636 |
| 7.2.5 | Register List.....                  | 641 |
| 7.2.6 | Register Description .....          | 643 |

# Figures

|                                                                                          |     |
|------------------------------------------------------------------------------------------|-----|
| Figure 7-1 SMHC Block Diagram .....                                                      | 623 |
| Figure 7-2 Command Token Format .....                                                    | 626 |
| Figure 7-3 Response Token Format .....                                                   | 626 |
| Figure 7-4 Data Packet Format for SDR .....                                              | 627 |
| Figure 7-5 Data Packet Format for DDR .....                                              | 628 |
| Figure 7-6 Data Packet Format for DDR in HS400 Mode .....                                | 629 |
| Figure 7-7 Single-Block and Multi-Block Read Operation .....                             | 630 |
| Figure 7-8 Single-Block and Multi-Block Read Operation .....                             | 630 |
| Figure 7-9 Phase Offset of Command and Data in SDR Mode .....                            | 631 |
| Figure 7-10 Phase Offset of Command and Data in DDR4 Mode (SMHC_NTSR[31] = 0) .....      | 632 |
| Figure 7-11 Phase Offset of Command and Data in DDR4 Mode .....                          | 632 |
| Figure 7-12 Phase Offset of Command and Data in DDR4 (2x Mode) (SMHC_NTSR[31] = 1) ..... | 633 |
| Figure 7-13 IDMAC Descriptor Structure Diagram.....                                      | 634 |

## Tables

|                                                                    |     |
|--------------------------------------------------------------------|-----|
| Table 7-1 SMHC Sub-blocks .....                                    | 623 |
| Table 7-2 SMHC External Signals.....                               | 624 |
| Table 7-3 SMHC0/1 Clock Sources .....                              | 624 |
| Table 7-4 SMHC2 Clock Sources.....                                 | 624 |
| Table 7-5 Speed Modes Supported by SD 3.0.....                     | 630 |
| Table 7-6 Speed Modes Supported by eMMC 5.0 .....                  | 631 |
| Table 7-7 Phase Offset of Command and Data in SDR Mode .....       | 632 |
| Table 7-8 Phase Offset of Command and Data in DDR4 (2x) Mode ..... | 633 |
| Table 7-9 DES0 Definition .....                                    | 634 |
| Table 7-10 DES1 Definition .....                                   | 635 |
| Table 7-11 DES2 Definition .....                                   | 635 |
| Table 7-12 DES3 Definition .....                                   | 635 |

## 7 Memory

### 7.1 SDRAM Controller (DRAMC)

The DRAMC is embedded with 128 MB DDR3.

The DRAMC has the following features:

- Embedded with 128 MB DDR3
- Supports clock frequency up to 800 MHz

## 7.2 SD/MMC Host Controller (SMHC)

### 7.2.1 Overview

The SMHC controls the read/write operations on the secure digital (SD) cards, multimedia cards (MMC), and various extended devices that is based on the secure digital input/output (SDIO) protocol. The processor provides three SMHC interfaces for controlling the SD cards, MMCs, and SDIO devices.

The SMHC has the following features:

- Supports Command Completion signals and interrupts to host processor, and Command Completion signal disable feature
- The SMHC0 controls the devices that comply with the Secure Digital Memory (SD mem-version 3.0)
- The SMHC1 controls the device that complies with the protocol Secure Digital I/O (SDIO-version 3.0)
- The SMHC2 controls the device that complies with the Multimedia Card (eMMC-version 5.0)
- Maximum performance:
  - SDR mode: 150 MHz@1.8 V IO pad
  - DDR mode: 50 MHz@1.8 V IO pad
  - DDR mode: 50 MHz@3.3 V IO pad
- Supports 1-bit or 4-bit data width
- Hardware CRC generation and error detection
- Programmable baud rate
- Supports SDIO interrupt in 1-bit and 4-bit modes
- Block size of 1 to 65535 bytes
- Descriptor-based internal DMA controller
- Internal 1 KB RXFIFO and 1 KB TXFIFO

### 7.2.2 Block Diagram

The following figure shows a block diagram of the SMHC.

**Figure 7-1 SMHC Block Diagram**

SMHC contains the following sub-blocks:

**Table 7-1 SMHC Sub-blocks**

| Sub-block | Description                                                                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Register  | Used to configure the control signal for reading or writing the SD/SDIO/eMMC.                                                                                                               |
| DMAC      | The DMA controller that controls the data transfer between the memory and SMHC.                                                                                                             |
| FIFO      | A buffer for the data stream between the memory and the SMHC asynchronous clock domain.                                                                                                     |
| SYNC      | Synchronizes the signals from the AHB clock domain to the SMHC clock domain.                                                                                                                |
| CMD Path  | Sends commands to or receives commands from the SD/SDIO/eMMC.                                                                                                                               |
| Data Path | Consists of Data TX and Data RX sub-modules. The Data TX sends data blocks and the CRC codes to the SD/SDIO/eMMC. The Data RX receives data blocks and the CRC codes from the SD/SDIO/eMMC. |

### 7.2.3 Functional Description

#### 7.2.3.1 External Signals

The following table describes the external signals of SMHC.

**Table 7-2 SMHC External Signals**

| <b>Port Name</b> | <b>Type</b> | <b>Description</b>                   |
|------------------|-------------|--------------------------------------|
| SDC0-CMD         | I/O, OD     | Command Signal for SD Card           |
| SDC0-CLK         | O           | Clock for SD Card                    |
| SDC0-D[3:0]      | I/O         | Data Input and Output for SD Card    |
| SDC0-RST         | O           | Reset for SD Card                    |
| SDC1-CMD         | I/O, OD     | Command Signal for SDIO Wi-Fi        |
| SDC1-CLK         | O           | Clock for SDIO Wi-Fi                 |
| SDC1-D[3:0]      | I/O         | Data Input and Output for SDIO Wi-Fi |
| SDC2-CMD         | I/O, OD     | Command Signal for eMMC              |
| SDC2-CLK         | O           | Clock for eMMC                       |
| SDC2-D[3:0]      | I/O         | Data Input and Output for eMMC       |

### 7.2.3.2 Clock Sources

The SMHC0/1 has 4 different clock sources. The SMHC2 has 5 different clock sources. You can select one of them as the SMHC clock source. The following table describes the clock sources of the SMHC.

For clock setting, configurations, and gating information, refer to section 3.3 “[CCU](#)”.

**Table 7-3 SMHC0/1 Clock Sources**

| <b>Clock Sources</b> | <b>Description</b>                             |
|----------------------|------------------------------------------------|
| HOSC                 | 24 MHz Crystal                                 |
| PLL_PERI(1X)         | Peripheral Clock, the default value is 600 MHz |
| PLL_PERI(2X)         | Peripheral Clock, the default value is 1.2 GHz |
| PLL_AUDIO1(DIV2)     | Audio clock, the default value is 1536 MHz     |

**Table 7-4 SMHC2 Clock Sources**

| <b>Clock Sources</b> | <b>Description</b>                             |
|----------------------|------------------------------------------------|
| HOSC                 | 24 MHz Crystal                                 |
| PLL_PERI(1X)         | Peripheral Clock, the default value is 600 MHz |
| PLL_PERI(2X)         | Peripheral Clock, the default value is 1.2 GHz |
| PLL_PERI(800M)       | Peripheral Clock, the default value is 800 MHz |
| PLL_AUDIO1(DIV2)     | Audio clock, the default value is 1536 MHz     |

### 7.2.3.3 Timing Diagram

Refer to the following relative specifications:

- Physical Layer Specification Ver3.00 Final
- SDIO Specification Ver2.00
- Multimedia Cards (MMC – version 4.2)
- JEDEC Standard – JESD84-44, Embedded Multimedia Card (eMMC) Card Product Standard
- JEDEC Standard – JESD84-B45, Embedded Multimedia Card (eMMC) Electrical Standard (4.5 Device)
- JEDEC Standard – JESD84-B50, Embedded Multimedia Card (eMMC) Electrical Standard (5.0)

### 7.2.3.4 Data Path

The SMHC and SD/SDIO/eMMC contains the following interface buses: CLK, CMD, and DATA 1/4. During one clock cycle, the SMHC can transmit one bit command with one or two bits data in 1-ch DATA mode, or four or eight bits data in 4-ch DATA mode. The CMD is a bidirection channel for initializing the SD/SDIO/eMMC and transmitting commands. It can work in both the open-drain mode and push-pull mode. The DATA is also a bidirection channel. It works in the push-pull mode.

#### Reading Data from the SD/SDIO/eMMC

The register configures the signals for the read operation, and synchronize the signals to the SMHC clock domain. Then the Data RX reads data from the SD/SDIO/eMMC via the CLK/CMD/DATA interface buses and writes the data in the FIFO. After that, the DMAC transfers the data from the FIFO to the memory.

#### Writing Data to the SD/SDIO/eMMC

The register configures the signals for the write operation, and synchronize the signals to the SMHC clock domain. Then the DMAC reads data from the memory and writes the data to the FIFO. After that, the Data TX reads the data from the FIFO and writes the data to the SD/SDIO/eMMC via the CLK/CMD/DATA interface buses.

### 7.2.3.5 Package Format

Data transfer over the SD/eMMC bus is based on command and data bitstreams that are initiated by a start bit and terminated by a stop bit. There are three types of SD/eMMC packets: command token, response token, and data packet.

### Command Tokens

The command token starts an operation. A command is sent from the host to a device. It is transferred serially on the CMD line. Command tokens have the following coding scheme:

**Figure 7-2 Command Token Format**



Each command token has 48 bits, preceded by a start bit ('0') and succeeded by an end bit ('1'). To detect transmission errors, each token is protected by CRC bits.

### Response Tokens

After receiving a command, the card returns a 48-bit or 136-bit response based on the command type.

A response token is sent from the device to the host as an answer to a previously received command. It is transferred serially on the CMD line.

**Figure 7-3 Response Token Format**



### Data Packets

Data can be transferred from the device to the host or vice versa. Data are transferred via the data lines.



T113x does not support the bus width of 8 bits.

**Figure 7-4 Data Packet Format for SDR**

**1 Bit Bus (only DAT0 used)**



**8 Bits Bus (DAT7 – DAT0 used)**



**4 Bits Bus (DAT3 – DAT0 used)**



**Figure 7-5 Data Packet Format for DDR**
**4 Bits Bus DDR (DAT3 – DAT0 used)**

**8 Bits Bus DDR (DAT7 – DAT0 used)**




- Bytes data are not interleaved but CRCs are interleaved.
- Start and end bits are only valid on the rising edge ("X" indicates "undefined").

**Figure 7-6 Data Packet Format for DDR in HS400 Mode**

**8 Bits Bus DDR for HS400 Output (DAT7 – DAT0 used)**



- Bytes data are not interleaved but CRCs are interleaved.
  - Start bits are valid when Data Strobe is High and Low.
  - End bits are only valid when Data Strobe is High ("X" indicates "undefined").

### 7.2.3.6 Data Transfer

Data transfers to or from the SD/eMMC card are done in blocks. Single and multiple block operations are widely used during data transfer.

The following figure shows the single-block and multi-block read operation.

**Figure 7-7 Single-Block and Multi-Block Read Operation**



The following figure shows the single-block and multi-block write operation.

**Figure 7-8 Single-Block and Multi-Block Write Operation**



### 7.2.3.7 Bus Speed Modes

The following table shows the bus speed modes supported by SD 3.0.

**Table 7-5 Speed Modes Supported by SD 3.0**

| Mode   | I/O Voltage | Bus Width | Frequency    | Throughput    |
|--------|-------------|-----------|--------------|---------------|
| SDR104 | 1.8 V       | 1, 4 bits | 0 to 208 MHz | 0 to 104 MB/s |

| Mode                    | I/O Voltage | Bus Width | Frequency   | Throughput   |
|-------------------------|-------------|-----------|-------------|--------------|
| SDR50                   | 1.8 V       | 1, 4 bits | 0 to 100MHz | 0 to 50 MB/s |
| DDR50                   | 1.8 V       | 1, 4 bits | 0 to 50 MHz | 0 to 50 MB/s |
| SDR25                   | 1.8 V       | 1, 4 bits | 0 to 50 MHz | 0 to 25 MB/s |
| SDR12                   | 1.8 V       | 1, 4 bits | 0 to 25 MHz | 0 to 12 MB/s |
| High Speed Mode (HS)    | 3.3 V       | 1, 4 bits | 0 to 50 MHz | 0 to 25 MB/s |
| Default Speed Mode (DS) | 3.3 V       | 1, 4 bits | 0 to 25 MHz | 0 to 12 MB/s |

The following table shows the bus speed modes supported by eMMC 5.0.

**Table 7-6 Speed Modes Supported by eMMC 5.0**

| Mode                                         | Data Rate | I/O Voltage | Bus Width | Frequency    | Throughput    |
|----------------------------------------------|-----------|-------------|-----------|--------------|---------------|
| Backwards Compatibility with legacy MMC card | Single    | 3.3 V/1.8 V | 1, 4 bits | 0 to 26 MHz  | 0 to 26 MB/s  |
| High Speed SDR                               | Single    | 3.3 V/1.8 V | 1, 4 bits | 0 to 52 MHz  | 0 to 52 MB/s  |
| High Speed DDR                               | Dual      | 3.3 V/1.8 V | 4 bits    | 0 to 52 MHz  | 0 to 104 MB/s |
| HS200                                        | Single    | 1.8 V       | 4 bits    | 0 to 200 MHz | 0 to 200 MB/s |

### 7.2.3.8 Phase Offset of the Command and Data

You can configure the phase offset of the command and data by the [SMHC\\_DRV\\_DL](#) register.

#### SDR Mode

The following figure shows the phase offset of SDR command and data.

**Figure 7-9 Phase Offset of Command and Data in SDR Mode**



**Table 7-7 Phase Offset of Command and Data in SDR Mode**

| Drive Delay | Command                                       | Data                                       |
|-------------|-----------------------------------------------|--------------------------------------------|
| 0           | The command is updated in 90° clock position  | The data is updated in 90° clock position  |
| 1           | The command is updated in 180° clock position | The data is updated in 180° clock position |

**DDR4 Mode**

The following figure shows the phase offset of DDR4 command and data.

**Figure 7-10 Phase Offset of Command and Data in DDR4 Mode ([SMHC\\_NTSR\[31\] = 0](#))****Figure 7-11 Phase Offset of Command and Data in DDR4 Mode**

| Drive Delay | Command                                       | Data                                             |
|-------------|-----------------------------------------------|--------------------------------------------------|
| 0           | The command is updated in 90° clock position  | The data is updated in 90° clock position        |
| 1           | The command is updated in 180° clock position | The data is updated in 0° or 180° clock position |

**DDR4 (2x) Mode**

The following figure shows the phase offset of DDR4 (2x mode) command and data.

Figure 7-12 Phase Offset of Command and Data in DDR4 (2x Mode) (SMHC\_NTSR[31] = 1)

DDR4 (2x mode) Drive Delay = 0



DDR4 (2x mode) Drive Delay = 1



Table 7-8 Phase Offset of Command and Data in DDR4 (2x) Mode

| Drive Delay | Command                                      | Data                                      |
|-------------|----------------------------------------------|-------------------------------------------|
| 0           | The command is updated in 45° clock position | The data is updated in 45° clock position |
| 1           | The command is updated in 90° clock position | The data is updated in 90° clock position |

### 7.2.3.9 Internal DMA Controller Description

The SMHC has an internal DMA controller (IDMAC) to transfer data between the host memory and SMHC port. With a descriptor, the IDMAC can efficiently move data from the source to destination by automatically loading the next DMA transfer arguments, which needs less CPU intervention. Before transferring data in the IDMAC, the host driver should construct a descriptor list, configure arguments of every DMA transfer, and then launch the descriptor and start the DMA.

The IDMAC has an interrupt controller. When enabled, it generates an interrupt to the HOST CPU in situations such as data transmission is completed or some error is happened.

#### IDMAC Descriptor Structure

The IDMAC uses a descriptor with a chain structure, and each descriptor points to a unique buffer and the next descriptor.

The following figure shows the internal formats of a descriptor.

**Figure 7-13 IDMAC Descriptor Structure Diagram**

This figure illustrates the internal formats of a descriptor. The descriptor address must be aligned to the bus width used for 32-bit buses. Each descriptor contains 16 bytes of control and status information.

DES0 corresponds to the [31:0] bits, DES1 corresponds to the [63:32] bits, DES2 corresponds to the [95:64] bits, and DES3 corresponds to the [127:96] bits in a descriptor.

The following table shows the bit definition of DES0.

**Table 7-9 DES0 Definition**

| Bits | Name                            | Description                                                                                                                                                                                                           |
|------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31   | HOLD                            | DES_OWN_FLAG<br>When set, this bit indicates that the descriptor is owned by the IDMAC. When this bit is reset, it indicates that the descriptor is owned by the host. This bit is cleared when the transfer is over. |
| 30   | ERROR                           | ERR_FLAG<br>When some errors happen in transfer, this bit will be set to 1.                                                                                                                                           |
| 29:5 | /                               | /                                                                                                                                                                                                                     |
| 4    | Chain Flag                      | CHAIN_MOD<br>When set to 1, this bit indicates that the second address in the descriptor is the next descriptor address. It must be set to 1.                                                                         |
| 3    | First DES Flag                  | FIRST_FLAG<br>When set to 1, this bit indicates that this descriptor contains the first buffer of data. It must be set to 1 in the first DES.                                                                         |
| 2    | Last DES Flag                   | LAST_FLAG<br>When set to 1, this bit indicates that the buffers this descriptor points to are the last data buffer.                                                                                                   |
| 1    | Disable Interrupt on completion | CUR_TXRX_OVER_INT_DIS<br>When set to 1, this bit will prevent the setting of the TX/RX interrupt bit of the IDMAC status register for data that ends in the buffer the descriptor points to.                          |
| 0    | /                               | /                                                                                                                                                                                                                     |

The following table shows the bit definition of DES1.

Table 7-10 DES1 Definition

| Bits  | Name        | Description                                                                                                                                                                         |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:13 | /           | /                                                                                                                                                                                   |
| 12:0  | Buffer size | BUFF_SIZE<br>The bits indicate the data buffer byte size, which must be a multiple of 4 bytes. If this field is 0, the DMA ignores this buffer and proceeds to the next descriptor. |

The following table shows the bit definition of DES2.

Table 7-11 DES2 Definition

| Bits | Name                   | Descriptor                                                                                       |
|------|------------------------|--------------------------------------------------------------------------------------------------|
| 31:0 | Buffer address pointer | BUFF_ADDR<br>The bits indicate the physical address of the data buffer.<br>It is a word address. |

The following table shows the bit definition of DES3.

Table 7-12 DES3 Definition

| Bits | Name                    | Descriptor                                                                                                                            |
|------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | Next descriptor address | NEXT_DESP_ADDR<br>The bits indicate the pointer to the physical memory where the next descriptor is present.<br>It is a word address. |

#### 7.2.3.10 Calibrating the Delay Chain

There are two delay chains in SMHC: data strobe delay chain and sample delay chain.

**Data strobe delay chain:** used to generate delay to make proper timing between Data Strobe and data signals.

**Sample delay chain:** used to generate delay to make proper timing between the internal card clock signal and data signals.

Each delay chain is made up with 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

Follow the steps below to calibrate the delay chain:

- Step 1** Enable SMHC. In order to calibrate the delay chain by the operation registers in SMHC, the SMHC must be enabled through [SMHC Bus Gating Reset Register](#) and [SMHCx Clock Register](#).
- Step 2** Configure a proper clock for SMHC. The delay chain calibration is based on the clock for SMHC from Clock Control Unit (CCU). The delay chain calibration is an internal function in SMHC and needs no devices. So it is unnecessary to open the clock signal for devices. The recommended clock frequency is 200 MHz.
- Step 3** Set proper initial delay value. Writing 0xA0 to **delay control register** enables **Delay Software Enable** (bit[7]) and sets initial delay value 0x20 to **Delay chain** (bit[5:0]). Then write 0x0 to **delay control register** to clear the value.
- Step 4** Write 0x8000 to **delay control register** to start calibrating the delay chain.
- Step 5** Wait until the flag (bit14 in **delay control register**) of calibration done is set. The number of delay cells is shown at bit[13:8] in **delay control register**. The delay time generated by these delay cells is equal to the cycle of the SMHC clock nearly. This value is the result of calibration.
- Step 6** Calculate the delay time of one delay cell according to the cycle of the SMHC clock and the result of calibration.

## 7.2.4 Programming Guidelines

### 7.2.4.1 Initializing SMHC

Before data and commands are exchanged between a card and the SMHC, the SMHC needs to be initialized. Follow the steps below to initialize the SMHC:

- Step 1** Configure the corresponding GPIO register as an SMHC by Port Controller module; reset clock by writing 1 to [SMHC\\_BGR\\_REG](#)[SMHC<sub>x</sub>\_RST], and open clock gating by writing 1 to [SMHC\\_BGR\\_REG](#)[SMHC<sub>x</sub>\_GATING]; select clock sources and set the division factor by configuring the [SMHC<sub>x</sub>\\_CLK\\_REG](#) ( $x = 0, 1$ ) register.
- Step 2** Configure [SMHC\\_CTRL](#) to reset the FIFO and controller, and enable the global interrupt; configure [SMHC\\_INTMASK](#) to 0xFFCE to enable normal interrupts and error abnormal interrupts, and then register the interrupt function.
- Step 3** Configure [SMHC\\_CLKDIV](#) to open clock for devices; configure [SMHC\\_CMD](#) as the change clock command (for example 0x80202000); send the update clock command to deliver clocks to devices.

- Step 4** Configure **SMHC\_CMD** as a normal command. Configure **SMHC\_CMDARG** to set command parameters. Configure **SMHC\_CMD** to set parameters like whether to send the response, the response type, and the response length and then send the commands. According to the initialization process in the protocol, you can finish SMHC initialization by sending the corresponding command one by one.

#### 7.2.4.2 Writing a Single Data Block

To write a single data block, follow the steps below:

- Step 1** Write 0x1 to **SMHC\_CTRL**[DMA\_RST] to reset the internal DMA controller; write 0x82 to **SMHC\_IDMAC** to enable the IDMAC interrupt and configure AHB master burst transfers; configure **SMHC\_IDIE** to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure **SMHC\_FIFOTH** to determine the burst size and TX/RX trigger level. For example, if **SMHC\_FIFOTH** is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure **SMHC\_DLBA** to determine the start address of the DMA descriptor.
- Step 3** To write one block data to sector1, configure **SMHC\_BYTCNT**[BYTE\_CNT] to 0x200 and configure the descriptor according to the data size; set the data sector address of CMD24 (Single Data Block Write) to 0x1, write 0x80002758 to **SMHC\_CMD**, and send CMD24 command to write data to the device.
- Step 4** Check whether **SMHC\_RINTSTS**[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether **SMHC\_IDST**[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to **SMHC\_IDST** to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether **SMHC\_RINTSTS**[DTC] is 1. If yes, the data transfer and CMD24 writing operations are completed. Otherwise, abnormality exists. Read **SMHC\_RINTSTS** and **SMHC\_STATUS** to query the existing abnormality.
- Step 7** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set **SMHC\_CMDARG** to 0x12340000, write 0x8000014D to **SMHC\_CMD**, go to step4 to ensure command transfer completed, and then check whether the highest bit of **SMHC\_RESP0** (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise, the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout.

#### 7.2.4.3 Reading a Single Data Block

To read a single data block, follow the steps below:

- Step 1** Write 0x1 to SMHC\_CTRL[DMA\_RST] to reset the internal DMA controller; write 0x82 to SMHC\_IDMAC to enable the IDMAC interrupt and configure AHB master burst transfers; configure SMHC\_IDIE to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure SMHC\_FIFOTH to determine the burst size and TX/RX trigger level. For example, if SMHC\_FIFOTH is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure SMHC\_DLBA to determine the start address of the DMA descriptor.
- Step 3** To read one block data from sector1, configure SMHC\_BYTCNT[BYTE\_CNT] to 0x200 and configure the descriptor according to the data size; set the data sector address of CMD17 command (Single Data Block Read) to 0x1, write 0x80002351 to SMHC\_CMD, and send CMD17 command to read data from the device to DRAM/SRAM.
- Step 4** Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether SMHC\_IDST[RX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to SMHC\_IDST to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether SMHC\_RINTSTS[DTC] is 1. If yes, data transfer and CMD17 reading operation are completed. Otherwise, abnormality exists. Read SMHC\_RINTSTS and SMHC\_STATUS to query the existing abnormality.

#### 7.2.4.4 Writing Open-Ended Multiple Data Blocks (CMD25 + Auto CMD12)

To write open-ended multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to SMHC\_CTRL[DMA\_RST] to reset the internal DMA controller; write 0x82 to SMHC\_IDMAC to enable the IDMAC interrupt and configure AHB master burst transfers; configure SMHC\_IDIE to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure SMHC\_FIFOTH to determine the burst size and TX/RX trigger level. For example, if SMHC\_FIFOTH is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure SMHC\_DLBA to determine the start address of the DMA descriptor.
- Step 3** To write three blocks of data to sectors begin with sector0, configure SMHC\_BYTCNT[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD25 command (Multiple Data Blocks Write) to 0x0, write 0x80003759 to SMHC\_CMD, and send CMD25 command to read data from the device to DRAM/SRAM.
- Step 4** Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.

- Step 5** Check whether SMHC\_IDST[RX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to SMHC\_IDST to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether SMHC\_RINTSTS [ACD] and SMHC\_RINTSTS[DTC] are both 1. If yes, the data transfer, CMD12 transfer, and CMD25 writing operations are completed. Otherwise, abnormality exists. Read SMHC\_RINTSTS and SMHC\_STATUS to query the existing abnormality.
- Step 7** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set SMHC\_CMDARG to 0x12340000, write 0x8000014D to SMHC\_CMD, go to step4 to ensure command transfer completed, and then check whether the highest bit of SMHC\_RESP0 (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise, the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout.

#### 7.2.4.5 Reading Open-Ended Multiple Data Blocks (CMD18 + Auto CMD12)

To read open-ended multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to SMHC\_CTRL[DMA\_RST] to reset the internal DMA controller; write 0x82 to SMHC\_IDMAC to enable the IDMAC interrupt and configure AHB master burst transfers; configure SMHC\_IDIE to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure SMHC\_FIFOTH to determine the burst size and TX/RX trigger level. For example, if SMHC\_FIFOTH is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure SMHC\_DLBA to determine the start address of the DMA descriptor.
- Step 3** To read three blocks of data from sectors begin with sector0, configure SMHC\_BYTCNT[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD18 command (Multiple Data Blocks Read) to 0x0, write 0x80003352 to SMHC\_CMD, and send CMD18 command to read data to the device. When the data transfer is completed, CMD12 will be sent automatically.
- Step 4** Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successfully; otherwise, continue to wait until timeout, and then exit the process.
- Step 5** Check whether SMHC\_IDST[RX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to SMHC\_IDST to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether SMHC\_RINTSTS [ACD] and SMHC\_RINTSTS[DTC] are both 1. If yes, data transfer, CMD12 transfer, and CMD18 reading operation are completed. Otherwise, abnormality exists. Read SMHC\_RINTSTS and SMHC\_STATUS to query the existing abnormality.

#### 7.2.4.6 Writing Pre-Defined Multiple Data Blocks (CMD23 + CMD25)

To write pre-defined multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to SMHC\_CTRL[DMA\_RST] to reset the internal DMA controller; write 0x82 to SMHC\_IDMAC to enable the IDMAC interrupt and configure AHB master burst transfers; configure SMHC\_IDIE to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure SMHC\_FIFOTH to determine the burst size and TX/RX trigger level. For example, if SMHC\_FIFOTH is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure SMHC\_DLBA to determine the start address of the DMA descriptor.
- Step 3** To write three blocks of data, configure SMHC\_CMDARG to 0x3 to specify the number of data blocks as three. Then write 0x80000157 to SMHC\_CMD to send the CMD23 command. Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 4** Configure SMHC\_BYTCNT[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD25 command (Multiple Data Blocks Write) to 0x0, write 0x80002759 to SMHC\_CMD, and send CMD25 command to write data to the device.
- Step 5** Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether SMHC\_IDST[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to SMHC\_IDST to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 7** Check whether SMHC\_RINTSTS[DTC] is 1. If yes, the data transfer and CMD25 writing operations are completed. Otherwise, abnormality exists. Read SMHC\_RINTSTS and SMHC\_STATUS to query the existing abnormality.
- Step 8** Send CMD13 command to query whether the device writing operation is completed and returns to the idle status. For example, device RCA is 0x1234, first set SMHC\_CMDARG to 0x12340000, write 0x8000014D to SMHC\_CMD, go to step4 to ensure command transfer completed, and then check whether the highest bit of SMHC\_RESP0 (CMD13 response) is 1. If yes, the device is in the idle status, and the next command can be sent. Otherwise, the device is in the busy status. Continue to send CMD13 to wait for the device to enter the idle status until timeout.

#### 7.2.4.7 Reading Pre-Defined Multiple Data Blocks (CMD23 + CMD18)

To read pre-defined multiple data blocks, follow the steps below:

- Step 1** Write 0x1 to SMHC\_CTRL[DMA\_RST] to reset the internal DMA controller; write 0x82 to SMHC\_IDMAC to enable the IDMAC interrupt and configure AHB master burst transfers; configure SMHC\_IDIE to enable the transfer interrupt, receive interrupt, and abnormal interrupt.
- Step 2** Configure SMHC\_FIFOTH to determine the burst size and TX/RX trigger level. For example, if SMHC\_FIFOTH is configured as 0x300F00F0, it indicates the burst size is 16, TX\_TL is 15, and RX\_TL is 240. Configure SMHC\_DLBA to determine the start address of the DMA descriptor.
- Step 3** To read three blocks of data, configure SMHC\_CMDARG to 0x3 to specify the number of data blocks as three. Then write 0x80000157 to SMHC\_CMD to send the CMD23 command. Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 4** Configure SMHC\_BYTCNT[BYTE\_CNT] to 0x600 and configure the descriptor according to the data size; set the data sector address of CMD18 (Multiple Data Blocks Read) to 0x0, write 0x80002352 to SMHC\_CMD, and send CMD18 command to read data from device to DRAM/SRAM.
- Step 5** Check whether SMHC\_RINTSTS[CC] is 1. If yes, the command is sent successful; otherwise, continue to wait until timeout, and then exit the process.
- Step 6** Check whether SMHC\_IDST[TX\_INT] is 1. If yes, the data transfer for writing DMA is completed. Write 0x337 to SMHC\_IDST to clear the interrupt flag. Otherwise, continue to wait until timeout, and then exit the process.
- Step 7** Check whether SMHC\_RINTSTS[DTC] is 1. If yes, the data transfer and CMD18 writing operations are completed. Otherwise, abnormality exists. Read SMHC\_RINTSTS and SMHC\_STATUS to query the existing abnormality.

### 7.2.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SMHC0       | 0x04020000   |
| SMHC1       | 0x04021000   |
| SMHC2       | 0x04022000   |

| Register Name | Offset | Description            |
|---------------|--------|------------------------|
| SMHC_CTRL     | 0x0000 | Control Register       |
| SMHC_CLKDIV   | 0x0004 | Clock Control Register |
| SMHC_TMOUT    | 0x0008 | Time Out Register      |
| SMHC_CTYPE    | 0x000C | Bus Width Register     |

| Register Name     | Offset | Description                                                  |
|-------------------|--------|--------------------------------------------------------------|
| SMHC_BLKSIZ       | 0x0010 | Block Size Register                                          |
| SMHC_BYTCNT       | 0x0014 | Byte Count Register                                          |
| SMHC_CMD          | 0x0018 | Command Register                                             |
| SMHC_CMDARG       | 0x001C | Command Argument Register                                    |
| SMHC_RESP0        | 0x0020 | Response 0 Register                                          |
| SMHC_RESP1        | 0x0024 | Response 1 Register                                          |
| SMHC_RESP2        | 0x0028 | Response 2 Register                                          |
| SMHC_RESP3        | 0x002C | Response 3 Register                                          |
| SMHC_INTMASK      | 0x0030 | Interrupt Mask Register                                      |
| SMHC_MINTSTS      | 0x0034 | Masked Interrupt Status Register                             |
| SMHC_RINTSTS      | 0x0038 | Raw Interrupt Status Register                                |
| SMHC_STATUS       | 0x003C | Status Register                                              |
| SMHC_FIFOTH       | 0x0040 | FIFO Water Level Register                                    |
| SMHC_FUNS         | 0x0044 | FIFO Function Select Register                                |
| SMHC_TCBCNT       | 0x0048 | Transferred Byte Count between Controller and Card           |
| SMHC_TBBCNT       | 0x004C | Transferred Byte Count between Host Memory and Internal FIFO |
| SMHC_DBGC         | 0x0050 | Current Debug Control Register                               |
| SMHC_CSDC         | 0x0054 | CRC Status Detect Control Registers                          |
| SMHC_A12A         | 0x0058 | Auto Command 12 Argument Register                            |
| SMHC_NTSR         | 0x005C | SD New Timing Set Register                                   |
| SMHC_HWRST        | 0x0078 | Hardware Reset Register                                      |
| SMHC_IDMAC        | 0x0080 | IDMAC Control Register                                       |
| SMHC_DLBA         | 0x0084 | Descriptor List Base Address Register                        |
| SMHC_IDST         | 0x0088 | IDMAC Status Register                                        |
| SMHC_IDIE         | 0x008C | IDMAC Interrupt Enable Register                              |
| SMHC_THLD         | 0x0100 | Card Threshold Control Register                              |
| SMHC_SFC          | 0x0104 | Sample FIFO Control Register                                 |
| SMHC_A23A         | 0x0108 | Auto Command 23 Argument Register                            |
| EMMC_DDR_SBIT_DET | 0x010C | eMMC4.5 DDR Start Bit Detection Control Register             |
| SMHC_EXT_CMD      | 0x0138 | Extended Command Register                                    |
| SMHC_EXT RESP     | 0x013C | Extended Response Register                                   |
| SMHC_DRV_DL       | 0x0140 | Drive Delay Control Register                                 |
| SMHC_SMAP_DL      | 0x0144 | Sample Delay Control Register                                |

| Register Name | Offset | Description                        |
|---------------|--------|------------------------------------|
| SMHC_DS_DL    | 0x0148 | Data Strobe Delay Control Register |
| SMHC_HS400_DL | 0x014C | HS400 Delay Control Register       |
| SMHC_FIFO     | 0x0200 | Read/Write FIFO                    |

## 7.2.6 Register Description

### 7.2.6.1 0x0000 SMHC Global Control Register (Default Value: 0x0000\_0100)

| Offset: 0x0000 |            |             | Register Name: SMHC_CTRL                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | FIFO_AC_MOD<br>FIFO Access Mode<br>0: DMA bus<br>1: AHB bus                                                                                                                                 |
| 30:13          | /          | /           | /                                                                                                                                                                                           |
| 12             | R/W        | 0x0         | TIME_UNIT_CMD<br>Time unit for command line<br>The time unit is used to calculate the command line time out value defined in RTO_LMT.<br>0: 1 card clock period<br>1: 256 card clock period |
| 11             | R/W        | 0x0         | TIME_UNIT_DAT<br>Time unit for data line<br>Time unit is used to calculate the data line time out value defined in DTO_LMT.<br>0: 1 card clock period<br>1: 256 card clock period           |
| 10             | R/W        | 0x0         | DDR_MOD_SEL<br>DDR Mode Select<br>Although the HS400 speed mode of eMMC is 8-bit DDR, this field should be cleared when HS400_MD_EN is set.<br>0: SDR mode<br>1: DDR mode                   |
| 9              | /          | /           | /                                                                                                                                                                                           |

| Offset: 0x0000 |            |             | Register Name: SMHC_CTRL                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 8              | R/W        | 0x1         | <p>CD_DBC_ENB<br/>Card Detect (Data[3] status) De-bounce Enable<br/>0: Disable de-bounce<br/>1: Enable de-bounce</p>                                     |
| 7:6            | /          | /           | /                                                                                                                                                        |
| 5              | R/W        | 0x0         | <p>DMA_ENB<br/>DMA Global Enable<br/>0: Disable DMA to transfer data via AHB bus<br/>1: Enable DMA to transfer data</p>                                  |
| 4              | R/W        | 0x0         | <p>INT_ENB<br/>Global Interrupt Enable<br/>0: Disable interrupts<br/>1: Enable interrupts</p>                                                            |
| 3              | /          | /           | /                                                                                                                                                        |
| 2              | R/W        | 0x0         | <p>DMA_RST<br/>DMA Reset</p>                                                                                                                             |
| 1              | R/W        | 0x0         | <p>FIFO_RST<br/>FIFO Reset<br/>0: No effect<br/>1: Reset the FIFO<br/>This bit is auto-cleared after the completion of the reset operation.</p>          |
| 0              | R/W        | 0x0         | <p>SOFT_RST<br/>Software Reset<br/>0: No effect<br/>1: Reset SD/MMC controller<br/>This bit is auto-cleared after the completion of reset operation.</p> |

#### 7.2.6.2 0x0004 SMHC Clock Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: SMHC_CLKDIV                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31             | R/W        | 0x0         | <p>MASK_DATA0<br/>0: Do not mask data0 when update clock<br/>1: Mask data0 when update clock</p> |
| 30:18          | /          | /           | /                                                                                                |

| Offset: 0x0004 |            |             | Register Name: SMHC_CLKDIV                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 17             | R/W        | 0x0         | CCLK_CTRL<br>Card Clock Output Control<br>0: Card clock is always on.<br>1: Turn off card clock when FSM is in IDLE state.                  |
| 16             | R/W        | 0x0         | CCLK_ENB<br>Card Clock Enable<br>0: Card Clock is off.<br>1: Card Clock is on.                                                              |
| 15:8           | /          | /           | /                                                                                                                                           |
| 7:0            | R/W        | 0x0         | CCLK_DIV<br>Card Clock Divider<br>n: Source clock is divided by 2*n. (n = 0 to 255)<br>When HS400_MD_EN is set, this field must be cleared. |

### 7.2.6.3 0x0008 SMHC Timeout Register (Default Value: 0xFFFF\_FF40)

| Offset: 0x0008 |            |             | Register Name: SMHC_TMOUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:8           | R/W        | 0xffffffff  | DTO_LMT<br>Data Timeout Limit<br>This field can set the time that the host waits for the data from the device.<br>Ensure to communicate with the device, this field must be set to the maximum that is greater than the time $N_{AC}$ .<br>About the $N_{AC}$ , the explanation is as follows:<br>When Host read data, data transmission from the Device starts after the access time delay $N_{AC}$ beginning from the end bit of the read command (ACMD51, CMD8, CMD17, and CMD18).<br>When the host reads multiple block (CMD18), a next block's data transmission from the Device starts after the access time delay $N_{AC}$ beginning from the end bit of the previous block.<br>When the host writes data, the value is no effect. |
| 7:0            | R/W        | 0x40        | RTO_LMT<br>Response Timeout Limit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

**7.2.6.4 0x000C SMHC Bus Width Register (Default Value: 0x0000\_0000)**

| Offset: 0x000C |            |             | Register Name: SMHC_CTYPE                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:2           | /          | /           | /                                                                               |
| 1:0            | R/W        | 0x0         | CARD_WID<br>Card Width<br>00: 1-bit width<br>01: 4-bit width<br>1x: 8-bit width |

**7.2.6.5 0x0010 SMHC Block Size Register (Default Value: 0x0000\_0200)**

| Offset: 0x0010 |            |             | Register Name: SMHC_BLKSIZ |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:16          | /          | /           | /                          |
| 15:0           | R/W        | 0x200       | BLK_SZ<br>Block Size       |

**7.2.6.6 0x0014 SMHC Byte Count Register (Default Value: 0x0000\_0200)**

| Offset: 0x0014 |            |             | Register Name: SMHC_BYTCNT                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:0           | R/W        | 0x200       | BYTE_CNT<br>Byte counter<br>The number of bytes to be transferred. It must be integer multiple of Block Size (BLK_SZ) for block transfers. |

## 7.2.6.7 0x0018 SMHC Command Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: SMHC_CMD                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
| 31             | R/W        | 0x0         | CMD_LOAD<br>Start Command<br>This bit is automatically cleared when the current command is sent. If there is no response error happens, a command complete interrupt bit (CMD_OVER) will be set in the interrupt register. Do not write any other commands until this bit is cleared. |
| 30:29          | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 28             | R/W        | 0x0         | VOL_SW<br>Voltage Switch<br>0: Normal command<br>1: Voltage switch command, set for CMD11 only.                                                                                                                                                                                       |
| 27             | R/W        | 0x0         | BOOT_ABST<br>Boot Abort<br>Setting this bit will terminate the boot operation.                                                                                                                                                                                                        |
| 26             | R/W        | 0x0         | EXP_BOOT_ACK<br>Expect Boot Acknowledge<br>When the software sets this bit along in mandatory boot operation, the controller expects a boot acknowledge start pattern of 0-1-0 from the selected card.                                                                                |
| 25:24          | R/W        | 0x0         | BOOT_MOD<br>Boot Mode<br>00: Normal command<br>01: Mandatory Boot operation<br>10: Alternate Boot operation<br>11: Reserved                                                                                                                                                           |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 21             | R/W        | 0x0         | PRG_CLK<br>Change Clock<br>0: Normal command<br>1: Change Card Clock<br>When this bit is set, the controller will change the clock domain and clock output. No commands will be sent.                                                                                                 |
| 20:16          | /          | /           | /                                                                                                                                                                                                                                                                                     |

| Offset: 0x0018 |            |             | Register Name: SMHC_CMD                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                              |
| 15             | R/W        | 0x0         | <p>SEND_INIT_SEQ<br/>Send Initialization<br/>0: Normal command sending<br/>1: Send initialization sequence before sending this command.</p>                                                                                                                              |
| 14             | R/W        | 0x0         | <p>STOP_ABТ_CMD<br/>Stop Abort Command<br/>0: Normal command sending<br/>1: Send Stop or Abort command to stop the current data transfer in progress. (CMD12, CMD52 for writing "I/O Abort" in SDIO CCCR)</p>                                                            |
| 13             | R/W        | 0x0         | <p>WAIT_PRE_OVER<br/>Wait for Data Transfer Over<br/>0: Send command at once, does not care about data transferring.<br/>1: Wait for data transfer completion before sending the current command.</p>                                                                    |
| 12             | R/W        | 0x0         | <p>STOP_CMD_FLAG<br/>Send Stop CMD Automatically (CMD12)<br/>0: Do not send stop command at the end of the data transfer.<br/>1: Send stop command automatically at the end of the data transfer.<br/>If set, the SMHC_RESP1 will record the response of auto CMD12.</p> |
| 11             | R/W        | 0x0         | <p>TRANS_MODE<br/>Transfer Mode<br/>0: Block data transfer command<br/>1: Stream data transfer command</p>                                                                                                                                                               |
| 10             | R/W        | 0x0         | <p>TRANS_DIR<br/>Transfer Direction<br/>0: Read operation<br/>1: Write operation</p>                                                                                                                                                                                     |
| 9              | R/W        | 0x0         | <p>DATA_TRANS<br/>Data Transfer<br/>0: Without data transfer<br/>1: With data transfer</p>                                                                                                                                                                               |

| Offset: 0x0018 |            |             | Register Name: SMHC_CMD                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 8              | R/W        | 0x0         | CHK_RESP_CRC<br>Check Response CRC<br>0: Do not check response CRC<br>1: Check response CRC |
| 7              | R/W        | 0x0         | LONG_RESP<br>Response Type<br>0: Short Response (48 bits)<br>1: Long Response (136 bits)    |
| 6              | R/W        | 0x0         | RESP_RCV<br>Response Receive<br>0: Command without response<br>1: Command with response     |
| 5:0            | R/W        | 0x0         | CMD_IDX<br>CMD Index<br>Command index value                                                 |

#### 7.2.6.8 0x001C SMHC Command Argument Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SMHC_CMDARG  |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:0           | R/W        | 0x0         | CMD_ARG<br>Command argument |

#### 7.2.6.9 0x0020 SMHC Response 0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SMHC_RESP0                        |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:0           | R          | 0x0         | CMD_RESP0<br>Response 0<br>Bit[31:0] of response |

### 7.2.6.10 0x0024 SMHC Response 1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: SMHC_RESP1                         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:0           | R          | 0x0         | CMD_RESP1<br>Response 1<br>Bit[63:31] of response |

### 7.2.6.11 0x0028 SMHC Response 2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: SMHC_RESP2                         |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:0           | R          | 0x0         | CMD_RESP2<br>Response 2<br>Bit[95:64] of response |

### 7.2.6.12 0x002C SMHC Response 3 Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: SMHC_RESP3                          |
|----------------|------------|-------------|----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                        |
| 31:0           | R          | 0x0         | CMD_RESP3<br>Response 3<br>Bit[127:96] of response |

### 7.2.6.13 0x0030 SMHC Interrupt Mask Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SMHC_INTMASK                          |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31             | R/W        | 0x0         | CARD_REMOVAL_INT_EN<br>Card Removed Interrupt Enable |
| 30             | R/W        | 0x0         | CARD_INSERT_INT_EN<br>Card Inserted Interrupt Enable |
| 29:17          | /          | /           | /                                                    |
| 16             | R/W        | 0x0         | SDIO_INT_EN<br>SDIO Interrupt Enable                 |

| Offset: 0x0030 |            |             | Register Name: SMHC_INTMASK                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 15             | R/W        | 0x0         | DEE_INT_EN<br>Data End-bit Error Interrupt Enable                            |
| 14             | R/W        | 0x0         | ACD_INT_EN<br>Auto Command Done Interrupt Enable                             |
| 13             | R/W        | 0x0         | DSE_BC_INT_EN<br>Data Start Error Interrupt Enable                           |
| 12             | R/W        | 0x0         | CB_IW_INT_EN<br>Command Busy and Illegal Write Interrupt Enable              |
| 11             | R/W        | 0x0         | FU_FO_INT_EN<br>FIFO Underrun/Overflow Interrupt Enable                      |
| 10             | R/W        | 0x0         | DSTO_VSD_INT_EN<br>Data Starvation Timeout/V1.8 Switch Done Interrupt Enable |
| 9              | R/W        | 0x0         | DTO_BDS_INT_EN<br>Data Timeout/Boot Data Start Interrupt Enable              |
| 8              | R/W        | 0x0         | RTO_BACK_INT_EN<br>Response Timeout/Boot ACK Received Interrupt Enable       |
| 7              | R/W        | 0x0         | DCE_INT_EN<br>Data CRC Error Interrupt Enable                                |
| 6              | R/W        | 0x0         | RCE_INT_EN<br>Response CRC Error Interrupt Enable                            |
| 5              | R/W        | 0x0         | DRR_INT_EN<br>Data Receive Request Interrupt Enable                          |
| 4              | R/W        | 0x0         | DTR_INT_EN<br>Data Transmit Request Interrupt Enable                         |
| 3              | R/W        | 0x0         | DTC_INT_EN<br>Data Transfer Complete Interrupt Enable                        |
| 2              | R/W        | 0x0         | CC_INT_EN<br>Command Complete Interrupt Enable                               |
| 1              | R/W        | 0x0         | RE_INT_EN<br>Response Error Interrupt Enable                                 |
| 0              | /          | /           | /                                                                            |

## 7.2.6.14 0x0034 SMHC Masked Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SMHC_MINTSTS                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                            |
| 31             | R          | 0x0         | M_CARD_REMOVAL_INT<br>Card Removed                                                                                                                                                                                                                                                                                     |
| 30             | R          | 0x0         | M_CARD_INSERT<br>Card Inserted                                                                                                                                                                                                                                                                                         |
| 29:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                      |
| 16             | R          | 0x0         | M_SDIO_INT<br>SDIO Interrupt                                                                                                                                                                                                                                                                                           |
| 15             | R          | 0x0         | M_DEE_EINT<br>Data End-bit Error<br>When the bit is set during receiving data, it means that the host controller does not receive the valid data end_bit.<br>When the bit is set during transmitting data, it means that the host controller does not receive the CRC status token.<br>This is a write-1-to-clear bit. |
| 14             | R          | 0x0         | M_ACD_INT<br>Auto Command Done<br>When set, it means auto-stop command (CMD12) completed.                                                                                                                                                                                                                              |
| 13             | R          | 0x0         | M_DSE_BC_INT<br>Data Start Error/Busy Clear<br>When set during receiving data, it means that the host controller found an error start bit.<br>When the bit is set during transmitting data, it means that the busy signal is cleared after the last block.                                                             |
| 12             | R          | 0x0         | M_CB_IW_INT<br>Command Busy and Illegal Write                                                                                                                                                                                                                                                                          |
| 11             | R          | 0x0         | M_FU_FO_INT<br>FIFO Underrun/Overflow                                                                                                                                                                                                                                                                                  |
| 10             | R          | 0x0         | M_DSTO_VSD_INT<br>Data Starvation Timeout/V1.8 Switch Done                                                                                                                                                                                                                                                             |
| 9              | R          | 0x0         | M.DTO_BDS_INT<br>Data Timeout/Boot Data Start                                                                                                                                                                                                                                                                          |
| 8              | R          | 0x0         | M.RTO_BACK_INT<br>Response Timeout/Boot ACK Received                                                                                                                                                                                                                                                                   |

| Offset: 0x0034 |            |             | Register Name: SMHC_MINTSTS                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                      |
| 7              | R          | 0x0         | M_DCE_INT<br>Data CRC Error<br><br>When the bit is set during receiving data, it means that the received data have data CRC error.<br><br>When the bit is set during transmitting data, it means that the received CRC status taken is negative. |
| 6              | R          | 0x0         | M_RCE_INT<br>Response CRC Error                                                                                                                                                                                                                  |
| 5              | R          | 0x0         | M_DRR_INT<br>Data Receive Request<br><br>When set, it means that there are enough data in FIFO during receiving data.                                                                                                                            |
| 4              | R          | 0x0         | M_DTR_INT<br>Data Transmit Request<br><br>When set, it means that there is enough space in FIFO during transmitting data.                                                                                                                        |
| 3              | R          | 0x0         | M_DTC_INT<br>Data Transfer Complete                                                                                                                                                                                                              |
| 2              | R          | 0x0         | M_CC_INT<br>Command Complete                                                                                                                                                                                                                     |
| 1              | R          | 0x0         | M_RE_INT<br>Response Error<br><br>When set, Transmit Bit error or End Bit error or CMD Index error may occurs.                                                                                                                                   |
| 0              | /          | /           | /                                                                                                                                                                                                                                                |

#### 7.2.6.15 0x0038 SMHC Raw Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                    |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31             | R/W1C      | 0x0         | CARD_REMOVAL<br>Card Removed<br><br>Write 1 to clear this bit. |

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                |
| 30             | R/W1C      | 0x0         | CARD_INSERT<br>Card Inserted<br>Write 1 to clear this bit.                                                                                                                                                                                                                                                 |
| 29:17          | /          | /           | /                                                                                                                                                                                                                                                                                                          |
| 16             | R/W1C      | 0x0         | SDIOI_INT<br>SDIO Interrupt<br>Write 1 to clear this bit.                                                                                                                                                                                                                                                  |
| 15             | R/W1C      | 0x0         | DEE<br>Data End-bit Error<br>When the bit is set during receiving data, it means that the host controller does not receive the valid data end bit.<br>When the bit is set during transmitting data, it means that the host controller does not receive the CRC status token.<br>Write 1 to clear this bit. |
| 14             | R/W1C      | 0x0         | ACD<br>Auto Command Done<br>When set, it means that the auto-stop command (CMD12) is completed.<br>Write 1 to clear this bit.                                                                                                                                                                              |
| 13             | R/W1C      | 0x0         | DSE_BC<br>Data Start Error/Busy Clear<br>When the bit is set during receiving data, it means that the host controller found an error start bit.<br>When the bit is set during transmitting data, it means that the busy signal is cleared after the last block.<br>Write 1 to clear this bit.              |
| 12             | R/W1C      | 0x0         | CB_IW<br>Command Busy and Illegal Write<br>Write 1 to clear this bit.                                                                                                                                                                                                                                      |
| 11             | R/W1C      | 0x0         | FU_FO<br>FIFO Underrun/Overflow<br>Write 1 to clear this bit.                                                                                                                                                                                                                                              |
| 10             | R/W1C      | 0x0         | DSTO_VSD<br>Data Starvation Timeout/V1.8 Switch Done<br>Write 1 to clear this bit.                                                                                                                                                                                                                         |

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                 |
| 9              | R/W1C      | 0x0         | <p>DTO_BDS<br/>Data Timeout/Boot Data Start<br/>When the bit is set during receiving data, it means that some of the channel of DATA[3:0] lack of the start bit.<br/>Write 1 to clear this bit.</p>                                                                         |
| 8              | R/W1C      | 0x0         | <p>RTO_BACK<br/>Response Timeout/Boot ACK Received<br/>Write 1 to clear this bit.</p>                                                                                                                                                                                       |
| 7              | R/W1C      | 0x0         | <p>DCE<br/>Data CRC Error<br/>When the bit is set during receiving data, it means that the received data have data CRC error.<br/>When the bit is set during transmitting data, it means that the received CRC status taken is negative.<br/>Write 1 to clear this bit.</p> |
| 6              | R/W1C      | 0x0         | <p>RCE<br/>Response CRC Error<br/>Write 1 to clear this bit.</p>                                                                                                                                                                                                            |
| 5              | R/W1C      | 0x0         | <p>DRR<br/>Data Receive Request<br/>When set, it means that there are enough data in FIFO during receiving data.<br/>Write 1 to clear this bit.</p>                                                                                                                         |
| 4              | R/W1C      | 0x0         | <p>DTR<br/>Data Transmit Request<br/>When set, it means that there is enough space in FIFO during transmitting data.<br/>Write 1 to clear this bit.</p>                                                                                                                     |
| 3              | R/W1C      | 0x0         | <p>DTC<br/>Data Transfer Complete<br/>When set, it means that the current command completes even through error occurs.<br/>Write 1 to clear this bit.</p>                                                                                                                   |

| Offset: 0x0038 |            |             | Register Name: SMHC_RINTSTS                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                        |
| 2              | R/W1C      | 0x0         | CC<br>Command Complete<br>When set, it means that the current command completes even through error occurs.<br>Write 1 to clear this bit.           |
| 1              | R/W1C      | 0x0         | RE<br>Response Error<br>When set, it means that the transmit bit error, end bit error, or CMD index error may occur.<br>Write 1 to clear this bit. |
| 0              | /          | /           | /                                                                                                                                                  |

#### 7.2.6.16 0x003C SMHC Status Register (Default Value: 0x0000\_0006)

| Offset: 0x003C |            |             | Register Name: SMHC_STATUS                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31             | R          | 0x0         | DMA_REQ<br>DMA Request<br>DMA request signal state                                                               |
| 30:26          | /          | /           | /                                                                                                                |
| 25:17          | R          | 0x0         | FIFO_LEVEL<br>FIFO Level<br>Number of filled locations in FIFO                                                   |
| 16:11          | R          | 0x0         | RESP_IDX<br>Response Index<br>Index of previous response, including any auto-stop sent by the controller.        |
| 10             | R          | 0x0         | FSM_BUSY<br>Data FSM Busy<br>Data transmit or receive state-machine is busy.                                     |
| 9              | R          | 0x0         | CARD_BUSY<br>Card Data Busy<br>Inverted version of DATA[0]<br>0: Card data is not busy.<br>1: Card data is busy. |

| Offset: 0x003C |            |             | Register Name: SMHC_STATUS                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 8              | R          | 0x0         | CARD_PRESENT<br>Data[3] Status<br>The level of DATA[3], checks whether the card is present.<br>0: The card is not present.<br>1: The card is present.                                                                                                                                                                                                                                                                                                                                     |
| 7:4            | R          | 0x0         | FSM_STA<br>Command FSM States<br>0000: Idle<br>0001: Send init sequence<br>0010: TX CMD start bit<br>0011: TX CMD TX bit<br>0100: TX CMD index + argument<br>0101: TX CMD CRC7<br>0110: TX CMD end bit<br>0111: RX response start bit<br>1000: RX response IRQ response<br>1001: RX response TX bit<br>1010: RX response CMD index<br>1011: RX response data<br>1100: RX response CRC7<br>1101: RX response end bit<br>1110: CMD path wait NCC<br>1111: Wait; CMD-to-response turn around |
| 3              | R          | 0x0         | FIFO_FULL<br>FIFO Full<br>0: FIFO is not full<br>1: FIFO is full                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2              | R          | 0x1         | FIFO_EMPTY<br>FIFO Empty<br>0: FIFO is not empty<br>1: FIFO is empty                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1              | R          | 0x1         | FIFO_TX_LEVEL<br>FIFO TX Water Level Flag<br>0: FIFO does not reach the transmit trigger level<br>1: FIFO reaches the transmit trigger level                                                                                                                                                                                                                                                                                                                                              |

| Offset: 0x003C |            |             | Register Name: SMHC_STATUS                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 0              | R          | 0x0         | <p>FIFO_RX_LEVEL<br/>FIFO RX Water Level Flag<br/>0: FIFO does not reach the receive trigger level.<br/>1: FIFO reaches the receive trigger level.</p> |

#### 7.2.6.17 0x0040 SMHC FIFO Water Level Register (Default Value: 0x000F\_0000)

| Offset: 0x0040 |            |             | Register Name: SMHC_FIFOTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 30:28          | R/W        | 0x0         | <p>BSIZE_OF_TRANS<br/>Burst Size of Multiple Transaction<br/>000: 1 transfers<br/>001: 4<br/>010: 8<br/>011: 16<br/>Others: Reserved<br/>It should be programmed the same as the DMA controller multiple transaction size. The units for the transfer are the DWORD. A single transfer would be signaled based on this value. The value should be sub-multiple of (RX_TL + 1) and (FIFO_DEPTH - TX_TL)<br/>Recommended:<br/>FIFO_DEPTH = 256, FIFO_SIZE = 256 * 32 = 1K<br/>MSize = 16, TX_TL = 240, RX_TL = 15</p> |
| 27:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0040 |            |             | Register Name: SMHC_FIFOOTH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:16          | R/W        | 0xF         | <p>RX_TL<br/>RX Trigger Level<br/>0x0 to 0xFE: The RX trigger level is from 0 to 254.<br/>0xFF: Reserved</p> <p>Indicates the FIFO threshold for the FIFO request host to receive data from the FIFO. When the FIFO data level is greater than this value, the DMA request is raised if DMA enabled, or the RX interrupt bit is set if interrupt enabled. At the end of the packet, if the last transfer is less than this level, the value is ignored and the relative request will be raised as usual.</p> <p>Recommended: 15 (means greater than 15)</p>                       |
| 15:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:0            | R/W        | 0x0         | <p>TX_TL<br/>TX Trigger Level<br/>0x1 to 0xFF: The TX trigger level is 1 to 255.<br/>0x0: No trigger</p> <p>Indicates the FIFO threshold for the FIFO request host to transmit data to the FIFO. When the FIFO data level is less than or equal to this value, the DMA TX request is raised if DMA enabled, or TX request interrupt bit is set if interrupt enabled. At the end of the packet, if the last transfer is less than this level, the value is ignored and the relative request will be raised as usual.</p> <p>Recommended: 240 (means less than or equal to 240)</p> |

#### 7.2.6.18 0x0044 SMHC Function Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SMHC_FUNS |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:3           | /          | /           | /                        |

| Offset: 0x0044 |            |             | Register Name: SMHC_FUNS                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2              | R/W        | 0x0         | <p>ABT_RDATA<br/>Abort Read Data<br/>0: Ignored<br/>1: After the suspend command is issued during the read-transfer, the software polls card to find when the suspend happens. Once the suspend occurs, the software sets the bit to reset the data state-machine, which is waiting for the next block of data.</p> <p>This bit is used in the SDIO card suspends sequence and is auto-cleared once the controller resets to the idle state.</p> |
| 1              | R/W        | 0x0         | <p>READ_WAIT<br/>Read Wait<br/>0: Clear SDIO read wait<br/>1: Assert SDIO read wait</p>                                                                                                                                                                                                                                                                                                                                                          |
| 0              | R/W        | 0x0         | <p>HOST_SEND_MMC_IRQRESQ<br/>Host Send MMC IRQ Response<br/>0: Ignored<br/>1: Send auto IRQ response</p> <p>When the host is waiting for the MMC card interrupt response, setting this bit will make the controller cancel the waiting state and return to the idle state, at which time, the controller will receive the IRQ response sent by itself.</p> <p>This bit is auto-cleared after the response is sent.</p>                           |

#### 7.2.6.19 0x0048 SMHC Transferred Byte Count Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SMHC_TBC0                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                               |
| 31:0           | R          | 0x0         | <p>TBC0<br/>Transferred Count 0<br/>The number of bytes transferred between the card and internal FIFO.<br/>The register should be accessed in full to avoid read-coherency problems and read only after the data transfer completes.</p> |

### 7.2.6.20 0x004C SMHC Transferred Byte Count Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SMHC_TBC1                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                          |
| 31:0           | R          | 0x0         | <p>TBC1<br/>Transferred Count 1<br/>The number of bytes transferred between the Host/DMA memory and internal FIFO.<br/>The register should be accessed in full to avoid read-coherency problems and read only after the data transfer completes.</p> |

### 7.2.6.21 0x0054 SMHC CRC Status Detect Control Register (Default Value: 0x0000\_0003)

| Offset: 0x0054 |            |             | Register Name: SMHC_CSDC                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:4           | /          | /           | /                                                                                            |
| 3:0            | R/W        | 0x3         | <p>CRC_DET PARA<br/>110: HS400 speed mode<br/>011: Other speed mode<br/>Others: Reserved</p> |

### 7.2.6.22 0x0058 SMHC Auto Command 12 Argument Register (Default Value: 0x0000\_FFFF)

| Offset: 0x0058 |            |             | Register Name: SMHC_A12A                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:16          | /          | /           | /                                                                                                           |
| 15:0           | R/W        | 0xffff      | <p>SD_A12A<br/>Auto CMD12 Argument<br/>The argument of command 12 automatically sent by the controller.</p> |

### 7.2.6.23 0x005C SMHC New Timing Set Register (Default Value: 0x8171\_0000)

| Offset: 0x005C |            |             | Register Name: SMHC_NTSR                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31             | R/W        | 0x1         | MODE_SELECT<br>0: Old mode of Sample/Output Timing<br>1: New mode of Sample/Output Timing                                                                                                                 |
| 30:25          | /          | /           | /                                                                                                                                                                                                         |
| 24             | R/W        | 0x1         | CMD_DAT_RX_PHASE_CLR<br>Clear the input phase of command lines and data lines during the update clock operation.<br>0: Disabled<br>1: Enabled                                                             |
| 23             | /          | /           | /                                                                                                                                                                                                         |
| 22             | R/W        | 0x1         | DAT_CRC_STATUS_RX_PHASE_CLR<br>Clear the input phase of data lines before receiving the CRC status.<br>0: Disabled<br>1: Enabled                                                                          |
| 21             | R/W        | 0x1         | DAT_TRANS_RX_PHASE_CLR<br>Clear the input phase of data lines before transferring the data.<br>0: Disabled<br>1: Enabled                                                                                  |
| 20             | R/W        | 0x1         | DAT_RECV_RX_PHASE_CLR<br>Clear the input phase of data lines before receiving the data.<br>0: Disabled<br>1: Enabled                                                                                      |
| 19:17          | /          | /           | /                                                                                                                                                                                                         |
| 16             | R/W        | 0x1         | CMD_SEND_RX_PHASE_CLR<br>Clear command rx phase before sending the command.<br>0: Disabled<br>1: Enabled                                                                                                  |
| 15:10          | /          | /           | /                                                                                                                                                                                                         |
| 9:8            | R/W        | 0x0         | DAT_SAMPLE_TIMING_PHASE<br>00: Sample timing phase offset 90°<br>01: Sample timing phase offset 180°<br>10: Sample timing phase offset 270°<br>11: Sample timing phase offset 0°(only for SD2 hs400 mode) |

| Offset: 0x005C |            |             | Register Name: SMHC_NTSR                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 7:6            | /          | /           | /                                                                                                                                                         |
| 5:4            | R/W        | 0x0         | CMD_SAMPLE_TIMING_PHASE<br>00: Sample timing phase offset 90°<br>01: Sample timing phase offset 180°<br>10: Sample timing phase offset 270°<br>11: Ignore |
| 3:1            | /          | /           | /                                                                                                                                                         |
| 0              | R/W        | 0x0         | HS400_NEW_SAMPLE_EN<br>0: Disable hs400 new sample method<br>1: Enable hs400 new sample method                                                            |

#### 7.2.6.24 0x0078 SMHC Hardware Reset Register (Default Value: 0x0000\_0001)

| Offset: 0x0078 |            |             | Register Name: SMHC_HWRST                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:1           | /          | /           | /                                                                                                                                         |
| 0              | R/W        | 0x1         | HW_RST<br>1: Active mode<br>0: Reset<br>These bits cause the cards to enter the pre-idle state, which requires them to be re-initialized. |

#### 7.2.6.25 0x0080 SMHC IDMAC Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: SMHC_IDMAC                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                        |
| 31             | W          | 0x0         | DES_LOAD_CTRL<br>When IDMAC fetches a descriptor, if the valid bit of a descriptor is not set, IDMAC FSM will go to the suspend state. Setting this bit will make the IDMAC refetch descriptor again and do the transfer normally. |
| 30:11          | /          | /           | /                                                                                                                                                                                                                                  |
| 10:8           | R          | 0x0         | Reserved                                                                                                                                                                                                                           |

| Offset: 0x0080 |            |             | Register Name: SMHC_IDMAC                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
| 7              | R/W        | 0x0         | IDMAC_ENB<br>IDMAC Enable<br>When set, the IDMAC is enabled.                                                                                                                                                                                                                                  |
| 6:2            | R/W        | 0x0         | Reserved                                                                                                                                                                                                                                                                                      |
| 1              | R/W        | 0x0         | FIX_BUST_CTRL<br>Fixed Burst<br>Controls whether the AHB Master interface performs fixed burst transfers or not. When set, the AHB will use only SINGLE, INCR4, and INCR8 during the start of normal burst transfers. When reset, the AHB will use SINGLE and INCR burst transfer operations. |
| 0              | R/W        | 0x0         | IDMAC_RST<br>DMA Reset<br>When set, the DMA Controller resets all its internal registers. It is automatically cleared after 1 clock cycle.                                                                                                                                                    |

#### 7.2.6.26 0x0084 SMHC Descriptor List Base Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: SMHC_DLBA_REG                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:0           | R/W        | 0x0         | DES_BASE_ADDR<br>Start of Descriptor List<br>Contains the base address of the First Descriptor.<br>It is a word (4 Byte) address. |

#### 7.2.6.27 0x0088 SMHC IDMAC Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST_REG |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:17          | /          | /           | /                            |
| 16:13          | R          | 0x0         | Reserved                     |

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST_REG                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                            |
| 12:10          | R          | 0x0         | <p>IDMAC_ERR_STA<br/>Error Bits<br/>Indicates the type of error that caused a Bus Error. Valid only with Fatal Bus Error bit (IDST[2]) set. This field does not generate an interrupt.</p> <p>001: Host Abort received during the transmission.<br/>010: Host Abort received during the reception.<br/>Others: Reserved</p>                                                                            |
| 9              | R/W1C      | 0x0         | <p>ABN_INT_SUM (AIS)<br/>Abnormal Interrupt Summary<br/>Logical OR of the following:<br/>IDST[2]: Fatal Bus Interrupt<br/>IDST[4]: Descriptor Unavailable Bit Interrupt<br/>IDST[5]: Card Error Summary Interrupt<br/>Only unmasked bits affect this bit.<br/>This is a sticky bit and must be cleared each time a corresponding bit that causes AIS to be set is cleared.</p>                         |
| 8              | R/W1C      | 0x0         | <p>NOR_INT_SUM (NIS)<br/>Normal Interrupt Summary<br/>Logical OR of the following:<br/>IDST[0]: Transmit Interrupt<br/>IDST[1]: Receive Interrupt<br/>Only unmasked bits affect this bit.<br/>This is a sticky bit and must be cleared each time a corresponding bit that causes NIS to be set is cleared.</p>                                                                                         |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5              | R/W1C      | 0x0         | <p>ERR_FLAG_SUM<br/>Card Error Summary<br/>Indicates the status of the transaction to/from the card; also present in RINTSTS. Indicates the logical OR of the following bits:</p> <p>EBC: End Bit Error<br/>RTO: Response Timeout<br/>RCRC: Response CRC<br/>SBE: Start Bit Error<br/>DRTO: Data Read Timeout<br/>DCRC: Data CRC for Receive<br/>RE: Response Error<br/>Writing 1 clears this bit.</p> |

| Offset: 0x0088 |            |             | Register Name: SMHC_IDST_REG                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                            |
| 4              | R/W1C      | 0x0         | <p>DES_UNAVAL_INT<br/>Descriptor Unavailable Interrupt<br/>This bit is set when the descriptor is unavailable due to OWN bit = 0 (DESO[31] =0). Writing 1 clears this bit.</p>                         |
| 3              | /          | /           | /                                                                                                                                                                                                      |
| 2              | R/W1C      | 0x0         | <p>FATAL_BERR_INT<br/>Fatal Bus Error Interrupt<br/>Indicates that a Bus Error occurred (IDST[12:10]). When this bit is set, the DMA disables all its bus accesses.<br/>Writing 1 clears this bit.</p> |
| 1              | R/W1C      | 0x0         | <p>RX_INT<br/>Receive Interrupt<br/>Indicates the completion of data reception for a descriptor.<br/>Writing 1 clears this bit.</p>                                                                    |
| 0              | R/W1C      | 0x0         | <p>TX_INT<br/>Transmit Interrupt<br/>Indicates that data transmission is finished for a descriptor.<br/>Writing 1 clears this bit.</p>                                                                 |

#### 7.2.6.28 0x008C SMHC IDMAC Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: SMHC_IDIE_REG                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 31:6           | /          | /           | /                                                                                                                                                                           |
| 5              | R/W        | 0x0         | <p>ERR_SUM_INT_ENB<br/>Card Error Summary Interrupt Enable.<br/>When set, it enables the Card Interrupt Summary.</p>                                                        |
| 4              | R/W        | 0x0         | <p>DES_UNAVAL_INT_ENB<br/>Descriptor Unavailable Interrupt.<br/>When set along with Abnormal Interrupt Summary Enable, the Descriptor Unavailable Interrupt is enabled.</p> |
| 3              | /          | /           | /                                                                                                                                                                           |

| Offset: 0x008C |            |             | Register Name: SMHC_IDIE_REG                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 2              | R/W        | 0x0         | FERR_INT_ENB<br>Fatal Bus Error Enable<br>When set with Abnormal Interrupt Summary Enable, the Fatal Bus Error Interrupt is enabled. When reset, the Fatal Bus Error Enable Interrupt is disabled. |
| 1              | R/W        | 0x0         | RX_INT_ENB<br>Receive Interrupt Enable.<br>When set with Normal Interrupt Summary Enable, Receive Interrupt is enabled. When reset, the Receive Interrupt is disabled.                             |
| 0              | R/W        | 0x0         | TX_INT_ENB<br>Transmit Interrupt Enable.<br>When set with Normal Interrupt Summary Enable, Transmit Interrupt is enabled. When reset, the Transmit Interrupt is disabled.                          |

#### 7.2.6.29 0x0100 SMHC Card Threshold Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: SMHC_THLD                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31:28          | /          | /           | /                                                                                                                                                                                                                                           |
| 27:16          | R/W        | 0x0         | CARD_WR_THLD<br>Card Read/Write Threshold Size                                                                                                                                                                                              |
| 15:3           | /          | /           | /                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x0         | CARD_WR_THLD_ENB<br>Card Write Threshold Enable<br>0: Card write threshold disabled<br>1: Card write threshold enabled<br>Host controller initiates write transfer only if the card threshold amount of data is available in transmit FIFO. |
| 1              | R/W        | 0x0         | BCIG<br>Busy Clear Interrupt Generation<br>0: Busy clear interrupt disabled<br>1: Busy clear interrupt enabled<br>The application can disable this feature if it does not want to wait for a Busy Clear Interrupt.                          |

| Offset: 0x0100 |            |             | Register Name: SMHC_THLD                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                           |
| 0              | R/W        | 0x0         | CARD_RD_THLD_ENB<br>Card Read Threshold Enable<br>0: Card read threshold disabled<br>1: Card read threshold enabled<br>Host controller initiates Read Transfer only if the CARD_RD_THLD amount of space is available in receive FIFO. |

#### 7.2.6.30 0x0104 SMHC Sample FIFO Control Register (Default Value: 0x0000\_0006)

| Offset: 0x0104 |            |             | Register Name: SMHC_SFC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4:1            | R/W        | 0x3         | STOP_CLK_CTRL<br>Stop Clock Control<br>When receiving data, if CARD_RD_THLD_ENB is set and CARD_RD_THLD is set the same with BLK_SZ, the device clock may stop at the block gap during data receiving.<br>This field is used to control the position of the stopping clock.<br>The value can be changed between 0x0 and 0xF, but actually, the available value and the position of the stopping clock must be decided by the actual situation.<br>The value increases one in this field is linked to one cycle (two cycles in DDR mode) that the position of the stopping clock moved up. |
| 0              | R/W        | 0x0         | BYPASS_EN<br>Bypass enable<br>When set, sample FIFO will be bypassed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 7.2.6.31 0x0108 SMHC Auto Command 23 Argument Register (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: SMHC_A23A                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31:0           | R/W        | 0x0         | A23A<br>Auto CMD23 Argument<br>The argument of command 23 is automatically sent by controller with this field. |

### 7.2.6.32 0x010C SMHC eMMC4.5 DDR Start Bit Detection Control Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: EMMC_DDR_SBIT_DET                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                |
| 31             | R/W        | 0x0         | <p>HS400_MD_EN<br/>HS400 Mode Enable<br/>0: Disabled<br/>1: Enabled<br/>It is required to set this bit to '1' before initiating any data transfer CMD in HS400 mode.</p>                                                                                                                   |
| 30:1           | /          | /           | /                                                                                                                                                                                                                                                                                          |
| 0              | R/W        | 0x0         | <p>HALF_START_BIT<br/>Control for start bit detection mechanism inside mstorage based on duration of start bit.<br/>For eMMC 4.5, start bit can be:<br/>0: Full cycle<br/>1: Less than one full cycle<br/>Set HALF_START_BIT = 1 for eMMC 4.5 and above; set to 0 for SD applications.</p> |

### 7.2.6.33 0x0138 SMHC Extended Command Register (Default Value: 0x0000\_0000)

| Offset: 0x0138 |            |             | Register Name: SMHC_EXT_CMD                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                |
| 31:1           | /          | /           | /                                                                                                                                                                                                                          |
| 0              | R/W        | 0x0         | <p>AUTO_CMD23_EN<br/>Send CMD23 Automatically<br/>When setting this bit, send CMD23 automatically before sending the command specified in the SMHC_CMD register.<br/>When SOFT_RST is set, this field will be cleared.</p> |

### 7.2.6.34 0x013C SMHC Extended Response Register (Default Value: 0x0000\_0000)

| Offset: 0x013C |            |             | Register Name: SMHC_EXT_RESP                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:0           | R          | 0x0         | SMHC_EXT_RESP<br>When AUTO_CMD23_EN is set, this register stores the response of CMD23. |

### 7.2.6.35 0x0140 SMHC Drive Delay Control Register (Default Value: 0x0001\_0000)

| Offset: 0x0140 |            |             | Register Name: SMHC_DRV_DL                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17             | R/W        | 0x0         | DAT_DRV_PH_SEL<br>Data Drive Phase Select<br><b>When 0x005C[31]=0:</b><br>0: Data drive phase offset is 90° at SDR mode, 45° at DDR8 mode, and 90° at DDR4 mode.<br>1: Data drive phase offset is 180° at SDR mode, 90° at DDR8 mode, and 0° at DDR4 mode.<br><b>When 0x005C[31]=1:</b><br>0: Data drive phase offset is 90° at SDR mode, and 45° at DDR mode.<br>1: Data drive phase offset is 180° at SDR mode, and 90° at DDR mode.                |
| 16             | R/W        | 0x1         | CMD_DRV_PH_SEL<br>Command Drive Phase Select<br><b>When 0x005C[31]=0:</b><br>0: Command drive phase offset is 90° at SDR mode, 45° at DDR8 mode, and 90° at DDR4 mode.<br>1: Command drive phase offset is 180° at SDR mode, 90° at DDR8 mode, and 180° at DDR4 mode.<br><b>When 0x005C[31]=1:</b><br>0: Command drive phase offset is 90° at SDR mode and 45° at DDR mode.<br>1: Command drive phase offset is 180° at SDR mode and 90° at DDR mode. |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 7.2.6.36 0x0144 SMHC Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0144 |            |             | Register Name: SMHC_SAMP_DL                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 15             | R/W        | 0x0         | SAMP_DL_CAL_START<br>Sample Delay Calibration Start<br>When set, it means that start sample delay chain calibration.                                                                                                                                                                                                                                         |
| 14             | R          | 0x0         | SAMP_DL_CAL_DONE<br>Sample Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.                                                                                                                                                                                       |
| 13:8           | R          | 0x20        | SAMP_DL<br>Sample Delay<br>It indicates the number of delay cells corresponding to the current card clock. The delay time generated by these delay cells is equal to the cycle of the card clock nearly.<br>Generally, it is necessary to do drive delay calibration when the card clock is changed.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | SAMP_DL_SW_EN<br>Sample Delay Software Enable<br>When set, it means that enable the sample delay specified at SAMP_DL_SW.                                                                                                                                                                                                                                    |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 5:0            | R/W        | 0x0         | SAMP_DL_SW<br>Sample Delay Software<br>The relative delay between the clock line and command line, data line.<br>It can be determined according to the value of SAMP_DL, the cycle of the card clock and the input timing requirement of the device.                                                                                                         |

### 7.2.6.37 0x0148 SMHC Data Strobe Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0148 |            |             | Register Name: SMHC_DS_DL |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:16          | /          | /           | /                         |

| Offset: 0x0148 |            |             | Register Name: SMHC_DS_DL                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                       |
| 15             | R/W        | 0x0         | DS_DL_CAL_START<br>Data Strobe Delay Calibration Start<br>When set, it means that start sample delay chain calibration.                                                                                                                                           |
| 14             | R          | 0x0         | DS_DL_CAL_DONE<br>Data Strobe Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in DS_DL.                                                                                           |
| 13:8           | R          | 0x20        | DS_DL<br>Data Strobe Delay<br>It indicates the number of delay cells corresponding to the current card clock. The delay time generated by these delay cells is equal to the cycle of SMHC's clock nearly.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | DS_DL_SW_EN<br>Sample Delay Software Enable                                                                                                                                                                                                                       |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                 |
| 5:0            | R/W        | 0x0         | DS_DL_SW<br>Data Strobe Delay Software                                                                                                                                                                                                                            |

#### 7.2.6.38 0x014C SMHC HS400 New Timing Delay Control Register (Default Value: 0x0000\_8000)

| Offset: 0x014C |            |             | Register Name: SMHC_HS400_DL                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                       |
| 15             | R/W        | 0x0         | HS400_DL_CAL_START<br>HS400 Delay Calibration Start<br>When set, it means that start sample delay chain calibration.                                                    |
| 14             | R          | 0x0         | HS400_DL_CAL_DONE<br>HS400 Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in HS400_DL. |
| 13:12          | /          | /           | /                                                                                                                                                                       |

| Offset: 0x014C |            |             | Register Name: SMHC_HS400_DL                                                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                               |
| 11:8           | R          | 0x8         | HS400_DL<br>HS400 Delay<br><br>It indicates the number of delay cells corresponding to the current card clock. The delay time generated by these delay cells is equal to the cycle of the SMHC clock nearly.<br><br>This bit is valid only when HS400_DL_CAL_DONE is set. |
| 7              | R/W        | 0x0         | HS400_DL_SW_EN<br>Sample Delay Software Enable                                                                                                                                                                                                                            |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | HS400_DL_SW<br>HS400 Delay Software                                                                                                                                                                                                                                       |

#### 7.2.6.39 0x0200 SMHC FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SMHC_FIFO |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | R/W        | 0x0         | TX/RX_FIFO<br>Data FIFO  |

# Contents

|       |                              |     |
|-------|------------------------------|-----|
| 8     | Audio .....                  | 678 |
| 8.1   | I2S/PCM.....                 | 678 |
| 8.1.1 | Overview .....               | 678 |
| 8.1.2 | Block Diagram .....          | 678 |
| 8.1.3 | Functional Description ..... | 680 |
| 8.1.4 | Programming Guidelines.....  | 686 |
| 8.1.5 | Register List.....           | 688 |
| 8.1.6 | Register Description .....   | 690 |
| 8.2   | DMIC.....                    | 738 |
| 8.2.1 | Overview .....               | 738 |
| 8.2.2 | Block Diagram .....          | 738 |
| 8.2.3 | Functional Description ..... | 738 |
| 8.2.4 | Register List.....           | 741 |
| 8.2.5 | Register Description .....   | 741 |
| 8.3   | OWA .....                    | 756 |
| 8.3.1 | Overview .....               | 756 |
| 8.3.2 | Block Diagram .....          | 757 |
| 8.3.3 | Functional Description ..... | 757 |
| 8.3.4 | Register List.....           | 762 |
| 8.3.5 | Register Description .....   | 762 |
| 8.4   | Audio Codec .....            | 772 |
| 8.4.1 | Overview .....               | 772 |
| 8.4.2 | Block Diagram .....          | 773 |
| 8.4.3 | Functional Description ..... | 773 |
| 8.4.4 | Programming Guidelines.....  | 781 |
| 8.4.5 | Register List.....           | 782 |
| 8.4.6 | Register Description .....   | 787 |

# Figures

|                                                           |     |
|-----------------------------------------------------------|-----|
| Figure 8-1 I2S/PCM Interface System Block Diagram .....   | 679 |
| Figure 8-2 Typical Application of I2S/PCM Interface ..... | 679 |
| Figure 8-3 I2S Standard Mode Timing.....                  | 681 |
| Figure 8-4 Left-Justified Mode Timing .....               | 681 |
| Figure 8-5 Right-Justified Mode Timing .....              | 682 |
| Figure 8-6 PCM Long Frame Mode Timing.....                | 682 |
| Figure 8-7 PCM Short Frame Mode Timing.....               | 682 |
| Figure 8-8 16-Channel Mapping Configuration.....          | 683 |
| Figure 8-9 Timing Requirements for Inputs .....           | 684 |
| Figure 8-10 Timing Requirements for Outputs .....         | 684 |
| Figure 8-11 I2S/PCM Operation Flow .....                  | 685 |
| Figure 8-12 DMIC Block Diagram .....                      | 738 |
| Figure 8-13 DMIC Operation Mode.....                      | 740 |
| Figure 8-14 OWA Block Diagram.....                        | 757 |
| Figure 8-15 OWA Biphasic-Mark Code .....                  | 758 |
| Figure 8-16 OWA Sub-Frame Format.....                     | 759 |
| Figure 8-17 OWA Frame/Block Format.....                   | 760 |
| Figure 8-18 OWA Operation Flow .....                      | 761 |
| Figure 8-19 Audio Codec Block Diagram.....                | 773 |
| Figure 8-20 Audio Codec Clock Diagram.....                | 774 |
| Figure 8-21 Audio Codec Digital Part Reset System.....    | 775 |
| Figure 8-22 Audio Codec Analog Part Reset System.....     | 775 |
| Figure 8-23 Audio Codec Data Path Diagram.....            | 776 |
| Figure 8-24 Headphone Output Application.....             | 777 |
| Figure 8-25 Audio Codec Interrupt System.....             | 778 |
| Figure 8-26 DAP Data Flow .....                           | 778 |
| Figure 8-27 HPF Logic Structure .....                     | 779 |
| Figure 8-28 DRC Block Diagram .....                       | 779 |
| Figure 8-29 DRC Static Curve Parameters.....              | 779 |
| Figure 8-30 Energy Filter Structure .....                 | 780 |

Figure 8-31 Gain Smooth Filter ..... 781

## Tables

|                                                                                            |     |
|--------------------------------------------------------------------------------------------|-----|
| Table 8-1 I2S/PCM External Signals .....                                                   | 680 |
| Table 8-2 I2S/PCM Clock Sources.....                                                       | 680 |
| Table 8-3 DIN Slot ID and Encoder .....                                                    | 683 |
| Table 8-4 Proper MCLK Values with Different Fsin and Fsout .....                           | 685 |
| Table 8-5 DMIC External Signals .....                                                      | 739 |
| Table 8-6 DMIC Clock Sources.....                                                          | 739 |
| Table 8-7 OWA Sub-blocks.....                                                              | 757 |
| Table 8-8 OWA External Signals .....                                                       | 757 |
| Table 8-9 OWA Clock Sources .....                                                          | 758 |
| Table 8-10 Biphase-Mark Encoder .....                                                      | 758 |
| Table 8-11 Preamble Codes .....                                                            | 760 |
| Table 8-12 The Corresponding Relation between Different System Clock and Sample Ratio..... | 760 |
| Table 8-13 Audio Codec External Signals .....                                              | 773 |

## 8 Audio

### 8.1 I2S/PCM

#### 8.1.1 Overview

The I2S/PCM controller is designed to transfer streaming audio-data between the system memory and the codec chip. The controller supports standard I2S format, Left-justified mode format, Right-justified mode format, PCM mode format, and TDM mode format.

The I2S/PCM controller includes the following features:

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

#### 8.1.2 Block Diagram

The following figure shows the functional block diagram of the I2S/PCM interface.

**Figure 8-1 I2S/PCM Interface System Block Diagram**

The following figure shows the typical application of the I2S/PCM interface.

**Figure 8-2 Typical Application of I2S/PCM Interface**

The I2S/PCM interface system integrates one I2S\_TX and one I2S\_RX.

- The I2S\_TX is for playing music in I2S or PCM format.
- The I2S\_RX is for receiving data in I2S or PCM format.
- When the I2S works in the master mode, the external I2S module provides BCLK\_in and LRCK\_in for the clock management unit (CMU), and the I2S\_TX and I2S\_RX work with the two external clocks.
- When the I2S works in the slave mode, the CMU provides clocks BCLK\_out and LRCK\_out for the external I2S module, and the I2S\_TX and I2S\_RX work with the internal clocks.

### 8.1.3 Functional Description

#### 8.1.3.1 External Signals

The following table describes the external signals of the I2S/PCM interface.

LRCK and BCLK are bidirectional I/O. When the I2S/PCM interface works in the Master mode, LRCK and BCLK are output pins. When the I2S/PCM interface works in the Slave mode, LRCK and BCLK are input pins.

MCLK is an output pin for external devices. DOUT are the serial data output pins and DIN are the serial data input pins. For details about General Purpose I/O port, refer to section 9.7 “[GPIO](#)”.

**Table 8-1 I2S/PCM External Signals**

| Signal Name    | Description                                | Type |
|----------------|--------------------------------------------|------|
| I2S1-MCLK      | I2S1 Master Clock                          | O    |
| I2S1-LRCK      | I2S1/PCM1 Sample Rate Clock/Sync           | I/O  |
| I2S1-BCLK      | I2S1/PCM1 Bit Rate Clock                   | I/O  |
| I2S1-DOUT[1:0] | I2S1/PCM1 Serial Data Output Channel [1:0] | O    |
| I2S1-DIN[1:0]  | I2S1/PCM1 Serial Data Input Channel [1:0]  | I    |
| I2S2-MCLK      | I2S2 Master Clock                          | O    |
| I2S2-LRCK      | I2S2/PCM2 Sample Rate Clock/Sync           | I/O  |
| I2S2-BCLK      | I2S2/PCM2 Bit Rate Clock                   | I/O  |
| I2S2-DOUT[2:0] | I2S2/PCM2 Serial Data Output Channel [2:0] | O    |
| I2S2-DIN[2:0]  | I2S2/PCM2 Serial Data Input Channel [2:0]  | I    |

#### 8.1.3.2 Clock Sources

The following table describes the clock sources for I2S/PCM. For clock setting, configurations, and gating information, refer to section 3.3 “[CCU](#)”.

**Table 8-2 I2S/PCM Clock Sources**

| Clock Name       | Description                                                                   |
|------------------|-------------------------------------------------------------------------------|
| PLL_AUDIO0(1X)   | By default, PLL_AUDIO0(1X) is 24.5714 MHz, and PLL_AUDIO0(4X) is 98.2856 MHz. |
| PLL_AUDIO0(4X)   |                                                                               |
| PLL_AUDIO1(DIV2) | By default, PLL_AUDIO1 is 3072 MHz, PLL_AUDIO1(DIV2) is 1536 MHz, and         |
| PLL_AUDIO1(DIV5) | PLL_AUDIO1(DIV5) is 614.4 MHz (24.576 MHz*25).                                |

### 8.1.3.3 Timing Diagram

The I2S/PCM supports standard I2S mode, Left-justified I2S mode, Right-justified I2S mode, PCM mode, and TDM mode. The software can select the modes by setting [I2S/PCM CTL](#). The following figures describe the waveforms for SYNC, BCLK, DOUT, and DIN in different modes.

Each sampling period contains an LRCK. The low level of LRCK is the left channel corresponding to the even slots, and the high level is the right channel corresponding to the odd slots. Each slot is the sampling point of a mono channel. The sampling period can support the transmission of 2/4/8/16 slots. The BCLK corresponds to the serial data bit.

**Figure 8-3 I2S Standard Mode Timing**



**Figure 8-4 Left-Justified Mode Timing**



**Figure 8-5 Right-Justified Mode Timing**

**Figure 8-6 PCM Long Frame Mode Timing**

**Figure 8-7 PCM Short Frame Mode Timing**


### 8.1.3.4 DIN Slot Mapping

The 4-wire DIN has 64 slots, each wire DIN has 16 slots. However, only 16 slots are valid and act as the RX channels.

The following table shows the relationship between the slot id and encoder.

**Table 8-3 DIN Slot ID and Encoder**

| DIN0 Slot ID | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
|--------------|---|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|
| DIN1 Slot ID | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| DIN2 Slot ID | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| DIN3 Slot ID | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |

There are 16 channels mapping configuration, each wire selects four slots for RX. The following figure shows the 16-channel mapping configuration.

**Figure 8-8 16-Channel Mapping Configuration**



### 8.1.3.5 ASRC

The ASRC module supports sampling rate conversion between the up-sampling and down-sampling. The ASRC also supports sampling rate conversion between dual-channel audio data, and the size of the sampling data is up to 24 bits.

The ASRC module has the following features:

- Typical THD + N: -130 dB (Range: -125 dB to -139 dB)
- Supports sampling rate conversion between the up-sampling and down-sampling to implement the sampling rate conversion for stereo data
  - The up-sampling ratio ranges from 1 to 7.5x

- The down-sampling ratio ranges from 8 to 1x
- Supports sampling rate conversion between two identical frequencies
- Sampling rate for both the input and output range is from 8 kHz to 192 kHz and can be decimal
- Sampling rate can be configured manually or via adaptive generation
- The ASRC input is connected to I2S RX\_FIFO\_WDATA [31:8], and the input data is 24-bit MSB big-endian. For the input data that is less than 24 bits, use zeros to pad out the values at the low bits instead of high bits
- The ASRC needs some time to calculate the result. The output outsamplea/b will keep 0 during the calculation, and then change to the valid value when the result comes out

### Calculating the ASRC Latency

Calculate the ASRC up-sampling and down-sampling latency according to the following formulas.

$$\text{Upsampling Latency} = \text{Phase Delay} + \text{FIFO Delay} = 32 + 16 = 48 \text{ Input Sample Periods}$$

$$\text{Downsampling Latency} = \text{Phase Delay} + \text{FIFO Delay} = (32 * f_{\text{out}} / f_{\text{in}}) + 16 \text{ Input Sample Periods}$$

### ASRC Timing

The MCLK samples the input clock CLKIN to generate pulse signals.

The following figure shows the timing requirements for the inputs.

**Figure 8-9 Timing Requirements for Inputs**



The following figure shows the timing requirements for the outputs.

**Figure 8-10 Timing Requirements for Outputs**



For the up-sampling,  $F_{MCLK} = F_{sout} * 1350$ .

For the down-sampling,  $F_{MCLK} = F_{sin} * 0.30 + F_{sout} * 295$ .

The following table provides the proper values of MCLK in MHz with different  $F_{sin}$  and  $F_{sout}$  in kHz.

**Table 8-4 Proper MCLK Values with Different  $F_{sin}$  and  $F_{sout}$**

| $F_{sout}$<br>$F_{sin}$ | 32  | 44.1 | 48  | 88.2 | 96  | 144 | 192 |
|-------------------------|-----|------|-----|------|-----|-----|-----|
| 32                      | 45  | 60   | 65  | 120  | 130 | 195 | 260 |
| 44.1                    | 55  | 60   | 65  | 120  | 130 | 195 | 260 |
| 48                      | 60  | 65   | 65  | 120  | 130 | 195 | 260 |
| 88.2                    | 105 | 105  | 110 | 120  | 130 | 195 | 260 |
| 96                      | 110 | 115  | 115 | 125  | 130 | 195 | 260 |
| 144                     | 160 | 165  | 165 | 175  | 180 | 195 | 260 |
| 192                     | 210 | 215  | 215 | 225  | 230 | 245 | 260 |

Note: The units for  $F_{sin}$  and  $F_{sout}$  are kHz and MCLK is MHz.

### 8.1.3.6 Operation Modes

The software operation of the I2S/PCM is divided into five steps: system setup, I2S/PCM initialization, the channel setup, DMA setup, and Enable/Disable module.

The following figure shows the whole operation flow of I2S/PCM.

**Figure 8-11 I2S/PCM Operation Flow**



## 1. System Setup and I2S/PCM Initialization

The clock source for the I2S/PCM should be followed. Firstly, disable the PLL\_AUDIO through [PLL\\_AUDIOx Control Register](#)[PLL\_ENABLE] in the CCU. Secondly, set up the frequency of the PLL\_AUDIO in the [PLL\\_AUDIOx Control Register](#). After that, enable the I2S/PCM gating through the [I2S/PCMx CLK REG](#) when you checkout that the [PLL\\_AUDIOx Control Register](#)[LOCK] becomes to 1. At last, reset and enable the I2S/PCM bus gating by setting [I2S/PCM BGR REG](#).

After the system setup, the register of I2S/PCM can be setup. Firstly, initialize the I2S/PCM. You should close the Globe Enable bit ([I2S/PCM CTL](#)[0]), Transmitter Block Enable bit ([I2S/PCM CTL](#)[2]), and Receiver Block Enable bit ([I2S/PCM CTL](#)[1]) by writing 0. After that, clear the TX/RX FIFO by writing 0 to the bit[25:24] of [I2S/PCM FCTL](#). At last, you can clear the TX FIFO and RX FIFO counter by writing 0 to [I2S/PCM TXCNT](#) and [I2S/PCM RXCNT](#).

## 2. Channel Setup and DMA Setup

First, you can set up the I2S/PCM of master and slave. The configuration can be referred to the protocol of I2S/PCM. Then, you can set up the translation mode, the sample resolution, the wide of the slot, the channel slot number, and the trigger level, and so on. The setup of the register can be found in the specification.

The I2S/PCM supports two methods to transfer the data. The most common way is DMA, the setup of DMA can be found in the “[DMA](#)”. In this module, you just enable the DRQ.

## 3. Enable and Disable I2S/PCM

To enable the function, you can enable TX/RX by writing [I2S/PCM CTL](#)[TXEN]/[I2S/PCM CTL](#)[RXEN]. After that, enable I2S/PCM by writing 1 to [I2S/PCM CTL](#)[Globe Enable]. Write 0 to the Globe Enable bit to disable I2S/PCM.

### 8.1.4 Programming Guidelines

#### 8.1.4.1 Application Example of Processing ASRC Input and Output Data

The following example shows a typical application of ASRC: the input data is 24-bit valid, and the output data is a 32-bit data whose highest 24 bits are valid output and the lowest eight bits are padded out with zeros.

To implement the application, configure the sample resolution and slot width as 32 bits. Follow the steps below:

**Step 1** For the input register: 0x04 [6:4] sample\_res = 3'h7, 0x04 [2:0] slot\_width = 3'h7.

The format of the input data: 32'hXXXXXXXX, where, bit[31] is the MSB and X is the valid data bit.

**Step 2** For the output register: 0x04 [6:4] sample\_res = 3'h7, 0x04 [2:0] slot\_width = 3'h7

The format of the output data: 32'hXXXXXX00, where, bit[31] is the MSB, X is the valid data bit, and bit[7:0] are the padded zeros.

#### 8.1.4.2 Converting the Sampling Rate with ASRC

Converting a 48 kHz sampling rate to 16 kHz is the most common scenario in actual applications. Follow the steps below to convert the sampling rate from 48 kHz to 16 kHz for the 32-bit data.

##### 1. Configure the PLL\_AUDIO Register

- a) Configure the [PLL\\_AUDIO0\\_CTRL\\_REG](#)[31:0] as 0x8814AB01. That is,  $\text{PLL\_AUDIO0} = 24 * (171+1)/(1+1)/(1+0)/(1+20) = 98.286 \text{ MHz}$ . According to the relationship among the  $F_{\text{sin}}$ ,  $F_{\text{fout}}$ , and MCLK, the MCLK should be greater than 60 MHz. In the simulation phase, the HOSC frequency is 25 MHz, so the output frequency of PLL\_AUDIO0 should be  $25 * (171+1)/(1+1)/(1+0)/(1+20) = 102.381 \text{ MHz}$ . In the IC test phase, configure the frequency of PLL\_AUDIO0 according to its actual output frequency.
- b) It is suggested that you configure the ASRC MCLK as an equal-duty-cycle signal. You can specify an odd number for bit[21:16] (PLL\_POST\_DIV\_P) of [PLL\\_AUDIO0\\_CTRL\\_REG](#) to get an equal-duty-cycle output clock of PLL\_AUDIO0.
- c) Configure bit[25:24] of [I2S/PCM2\\_ASRC\\_CLK\\_REG](#) as 0x00 to select the PLL\_AUDIO0(4X).

##### 2. Configure the I2S Registers

- a) Configure bit[7:4] (BCLKDIV) of [I2S/PCM\\_CLKD](#) as 4'h9, that is, the frequency of BCLK will be  $98.286 \text{ MHz}/32 = 3.072 \text{ MHz}$ .
- b) Configure bit[17:8] (LRCK\_PERIOD) of [I2S/PCM\\_FMT0](#) as 10'h1F. That is, the LRCK\_PERIOD width is configured as 32 BLCKs and can generate the ASRC CLKIN with a 48 kHz sampling rate.  
$$\left(\frac{3.072 \text{ MHz}}{32 * 2}\right) = 48 \text{ kHz}$$
- c) Configure bit[6:4] (Sample Resolution bits) of [I2S/PCM\\_FMT0](#) as 3'h7 to specify the sample resolution as 32-bit.
- d) Configure bit[2:0] (Slot Width bits) of [I2S/PCM\\_FMT0](#) as 3'h7 to specify the slot width as 32-bit.

##### 3. Configure the ASRC Registers

- a) Configure bit[16] (clock gate) of [MCLKCFG](#) as 1'h1 to open the clock gating.
- b) Configure bit[3:0] (division factor) of [MCLKCFG](#) as 1'h1 to specify the division factor as 1.
- c) Configure bit[20] (clock gate) of [FSOUTCFG](#) as 1'h1 to open the clock gating.

- d) Configure bit[19:16] (clock select) of [FsoutCFG](#) as 4`h0 to select I2S0\_ASRC\_CLK as the clock source.
- e) Configure bit[7:4] (the first division factor) of [FsoutCFG](#) as 16`h13 to configure the first division factor as 128.
- f) Configure bit[3:0] (the second division factor) of [FsoutCFG](#) as 16`h10 to configure the second division factor as 48.
- g) Configure the ASRC ratio.

To configure the ASRC ratio manually, configure bit[31] ([Manual Configuration of ASRC Ratio Enable](#)) of ASRCMANCFG as 1`h1 to enable the manual configuration of ASRC ratio. Configure bit[25:0] of ASRCMANCFG as 26`h155555 to specify the ratio value as 0x155555. The calculation formula for the ratio value: Dec2Hex (Fsout/Fsin)\*2<sup>22</sup>). In this example, Fsout/Fsin = 16 kHz/48 kHz =1/3, then the ratio is 0x155555.

To configure the ASRC ratio automatically, configure bit[31] ([Manual Configuration of ASRC Ratio Enable](#)) of ASRCMANCFG as 1`h0 to enable the automatic configuration of ASRC ratio. Then the system will automatically calculate the ratio value based on the MCLK, Fsout, and Fsin.

### 8.1.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| I2S/PCM1    | 0x02033000   |
| I2S/PCM2    | 0x02034000   |

| Register Name  | Offset | Description                              |
|----------------|--------|------------------------------------------|
| I2S/PCM_CTL    | 0x0000 | I2S/PCM Control Register                 |
| I2S/PCM_FMT0   | 0x0004 | I2S/PCM Format Register 0                |
| I2S/PCM_FMT1   | 0x0008 | I2S/PCM Format Register 1                |
| I2S/PCMISTA    | 0x000C | I2S/PCM Interrupt Status Register        |
| I2S/PCM_RXFIFO | 0x0010 | I2S/PCM RXFIFO Register                  |
| I2S/PCM_FCTL   | 0x0014 | I2S/PCM FIFO Control Register            |
| I2S/PCM_FSTA   | 0x0018 | I2S/PCM FIFO Status Register             |
| I2S/PCM_INT    | 0x001C | I2S/PCM DMA & Interrupt Control Register |
| I2S/PCM_TXFIFO | 0x0020 | I2S/PCM TXFIFO Register                  |
| I2S/PCM_CLKD   | 0x0024 | I2S/PCM Clock Divide Register            |
| I2S/PCM_TXCNT  | 0x0028 | I2S/PCM TX Sample Counter Register       |
| I2S/PCM_RXCNT  | 0x002C | I2S/PCM RX Sample Counter Register       |

| Register Name     | Offset | Description                                           |
|-------------------|--------|-------------------------------------------------------|
| I2S/PCM_CHCFG     | 0x0030 | I2S/PCM Channel Configuration Register                |
| I2S/PCM_TX0CHSEL  | 0x0034 | I2S/PCM TX0 Channel Select Register                   |
| I2S/PCM_TX1CHSEL  | 0x0038 | I2S/PCM TX1 Channel Select Register                   |
| I2S/PCM_TX2CHSEL  | 0x003C | I2S/PCM TX2 Channel Select Register                   |
| I2S/PCM_TX3CHSEL  | 0x0040 | I2S/PCM TX3 Channel Select Register                   |
| I2S/PCM_TX0CHMAP0 | 0x0044 | I2S/PCM TX0 Channel Mapping Register0                 |
| I2S/PCM_TX0CHMAP1 | 0x0048 | I2S/PCM TX0 Channel Mapping Register1                 |
| I2S/PCM_TX1CHMAP0 | 0x004C | I2S/PCM TX1 Channel Mapping Register0                 |
| I2S/PCM_TX1CHMAP1 | 0x0050 | I2S/PCM TX1 Channel Mapping Register1                 |
| I2S/PCM_TX2CHMAP0 | 0x0054 | I2S/PCM TX2 Channel Mapping Register0                 |
| I2S/PCM_TX2CHMAP1 | 0x0058 | I2S/PCM TX2 Channel Mapping Register1                 |
| I2S/PCM_TX3CHMAP0 | 0x005C | I2S/PCM TX3 Channel Mapping Register0                 |
| I2S/PCM_TX3CHMAP1 | 0x0060 | I2S/PCM TX3 Channel Mapping Register1                 |
| I2S/PCM_RXCHSEL   | 0x0064 | I2S/PCM RX Channel Select Register                    |
| I2S/PCM_RXCHMAP0  | 0x0068 | I2S/PCM RX Channel Mapping Register0                  |
| I2S/PCM_RXCHMAP1  | 0x006C | I2S/PCM RX Channel Mapping Register1                  |
| I2S/PCM_RXCHMAP2  | 0x0070 | I2S/PCM RX Channel Mapping Register2                  |
| I2S/PCM_RXCHMAP3  | 0x0074 | I2S/PCM RX Channel Mapping Register3                  |
| MCLKCFG           | 0x0080 | ASRC MCLK Configuration Register                      |
| FsoutCFG          | 0x0084 | ASRC Out Sample Rate Configuration Register           |
| FsinEXTCFG        | 0x0088 | ASRC Input Sample Pulse Extend Configuration Register |
| ASRCCFG           | 0x008C | ASRC Enable Register                                  |
| ASRCMANCFG        | 0x0090 | ASRC Manual Ratio Configuration Register              |
| ASRCRATIOSTAT     | 0x0094 | ASRC Status Register                                  |
| ASRCFIFOSTAT      | 0x0098 | ASRC FIFO Level Status Register                       |
| ASRCMBISTCFG      | 0x009C | ASRC MBIST Test Configuration Register                |
| ASRCMBISTSTAT     | 0x00A0 | ASRC MBIST Test Status Register                       |

### 8.1.6 Register Description

#### 8.1.6.1 0x0000 I2S/PCM Control Register (Default Value: 0x0006\_0000)

| Offset: 0x0000 |            |             | Register Name: I2S/PCM_CTL                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 31:22          | /          | /           | /                                                                                                                                              |
| 21             | R/W        | 0x0         | RX_SYNC_EN_START<br>The bit takes effect only when RX_SYNC_EN is set to 1.<br>I2S1/I2S2 Synchronize Enable Start.<br>0: Disabled<br>1: Enabled |
| 20             | R/W        | 0x0         | RX_SYNC_EN<br>I2S RX Synchronize Enable<br>0: Disabled<br>1: Enabled                                                                           |
| 19             | /          | /           | /                                                                                                                                              |
| 18             | R/W        | 0x1         | BCLK_OUT<br>Bit Clock Direction Select<br>0: Input<br>1: Output                                                                                |
| 17             | R/W        | 0x1         | LRCK_OUT<br>LRCK Direction Select<br>0: Input<br>1: Output                                                                                     |
| 16:12          | /          | /           | /                                                                                                                                              |
| 11             | R/W        | 0x0         | DOUT3_EN<br>Data3 Output Enable<br>0: Disabled, Hi-Z State<br>1: Enabled                                                                       |
| 10             | R/W        | 0x0         | DOUT2_EN<br>Data2 Output Enable<br>0: Disabled, Hi-Z State<br>1: Enabled                                                                       |
| 9              | R/W        | 0x0         | DOUT1_EN<br>Data1 Output Enable<br>0: Disabled, Hi-Z State<br>1: Enabled                                                                       |

| Offset: 0x0000 |            |             | Register Name: I2S/PCM_CTL                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 8              | R/W        | 0x0         | DOUT0_EN<br>Data0 Output Enable<br>0: Disabled, Hi-Z State<br>1: Enabled                                                                                                                      |
| 7              | /          | /           | /                                                                                                                                                                                             |
| 6              | R/W        | 0x0         | OUT_MUTE<br>Data Output Mute Enable<br>0: Normal Transfer<br>1: Force DOUT to output 0                                                                                                        |
| 5:4            | R/W        | 0x0         | MODE_SEL<br>Mode Selection<br>00: PCM Mode (offset 0: Long Frame; offset 1: Short Frame)<br>01: Left Mode (offset 0: LJ Mode; offset 1: I2S Mode)<br>10: Right-Justified Mode<br>11: Reserved |
| 3              | R/W        | 0x0         | LOOP<br>Loopback Test<br>0: Normal Mode<br>1: Loopback Test<br>When set to '1', the bit indicates that the DOUT is connected to the DIN.                                                      |
| 2              | R/W        | 0x0         | TXEN<br>Transmitter Block Enable<br>0: Disabled<br>1: Enabled                                                                                                                                 |
| 1              | R/W        | 0x0         | RXEN<br>Receiver Block Enable<br>0: Disabled<br>1: Enabled                                                                                                                                    |
| 0              | R/W        | 0x0         | GEN<br>Globe Enable<br>0: Disabled<br>1: Enabled                                                                                                                                              |

### 8.1.6.2 0x0004 I2S/PCM Format Register 0 (Default Value: 0x0000\_0033)

| Offset: 0x0004 |            |             | Register Name: I2S/PCM_FMT0                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                           |
| 31             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                     |
| 30             | R/W        | 0x0         | LRCK_WIDTH<br>LRCK Width (only applies to the PCM mode)<br>0: LRCK = 1 BCLK Width (Short Frame)<br>1: LRCK = 2 BCLK Width (Long Frame)                                                                                                                                                                                                                                                |
| 29:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                     |
| 19             | R/W        | 0x0         | LRCK_POLARITY<br>In I2S/Left-Justified/Right-Justified mode:<br>0: Left Channel when LRCK is low.<br>1: Left channel when LRCK is high.<br>In PCM mode:<br>0: PCM LRCK asserted at the negative edge.<br>1: PCM LRCK asserted at the positive edge.                                                                                                                                   |
| 18             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                     |
| 17:8           | R/W        | 0x0         | LRCK_PERIOD<br>It is used to program the number of BCLKs per channel of the sample frame. This value is interpreted as follows.<br>PCM mode: Number of BCLKs within (Left + Right) channel width.<br>I2S/Left-Justified/Right-Justified mode: Number of BCLKs within each channel width (Left or Right).<br>For example:<br>N = 7: 8 BCLKs width<br>...<br>N = 1023: 1024 BCLKs width |
| 7              | R/W        | 0x0         | BCLK_POLARITY<br>0: Normal mode, DOUT drives data at negative edge<br>1: Invert mode, DOUT drives data at positive edge                                                                                                                                                                                                                                                               |

| Offset: 0x0004 |            |             | Register Name: I2S/PCM_FMT0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:4            | R/W        | 0x3         | <p>SR</p> <p>Sample Resolution</p> <p>000: Reserved</p> <p>001: 8-bit</p> <p>010: 12-bit</p> <p>011: 16-bit</p> <p>100: 20-bit</p> <p>101: 24-bit</p> <p>110: 28-bit</p> <p>111: 32-bit</p>                                                                                                                                                                                                                                                                                                                          |
| 3              | R/W        | 0x0         | <p>EDGE_TRANSFER</p> <p>Edge Transfer</p> <p>0: DOUT drives data and DIN sample data at the different BCLK edge</p> <p>1: DOUT drives data and DIN sample data at the same BCLK edge</p> <p>BCLK_POLARITY = 0, EDGE_TRANSFER = 0, DIN sample data at positive edge;</p> <p>BCLK_POLARITY = 0, EDGE_TRANSFER = 1, DIN sample data at negative edge;</p> <p>BCLK_POLARITY = 1, EDGE_TRANSFER = 0, DIN sample data at negative edge;</p> <p>BCLK_POLARITY = 1, EDGE_TRANSFER = 1, DIN sample data at positive edge.</p> |
| 2:0            | R/W        | 0x3         | <p>SW</p> <p>Slot Width Select</p> <p>000: Reserved</p> <p>001: 8-bit</p> <p>010: 12-bit</p> <p>011: 16-bit</p> <p>100: 20-bit</p> <p>101: 24-bit</p> <p>110: 28-bit</p> <p>111: 32-bit</p>                                                                                                                                                                                                                                                                                                                          |

### 8.1.6.3 0x0008 I2S/PCM Format Register 1 (Default Value: 0x0000\_0030)

| Offset: 0x0008 |            |             | Register Name: I2S/PCM_FMT1                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                                                                                                      |
| 7              | R/W        | 0x0         | RX MLS<br>MSB/LSB First Select<br>0: MSB First<br>1: LSB First                                                                                                                                                         |
| 6              | R/W        | 0x0         | TX MLS<br>MSB/LSB First Select<br>0: MSB First<br>1: LSB First                                                                                                                                                         |
| 5:4            | R/W        | 0x3         | SEXT<br>Sign Extend in Slot [Sample Resolution < Slot Width]<br>00: Zeros or audio gain padding at LSB position<br>01: Sign extension at MSB position<br>10: Reserved<br>11: Transfer 0 after each sample in each Slot |
| 3:2            | R/W        | 0x0         | RX_PDM<br>PCM Data Mode<br>00: Linear PCM<br>01: Reserved<br>10: 8-bit u-law<br>11: 8-bit A-law                                                                                                                        |
| 1:0            | R/W        | 0x0         | TX_PDM<br>PCM Data Mode<br>00: Linear PCM<br>01: Reserved<br>10: 8-bit u-law<br>11: 8-bit A-law                                                                                                                        |

### 8.1.6.4 0x000C I2S/PCM Interrupt Status Register (Default Value: 0x0000\_0010)

| Offset: 0x000C |            |             | Register Name: I2S/PCMISTA |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:7           | /          | /           | /                          |

| Offset: 0x000C |            |             | Register Name: I2S/PCMISTA                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 6              | R/W1C      | 0x0         | <p>TXU_INT<br/>TXFIFO Underrun Pending Interrupt<br/>0: No pending interrupt<br/>1: TXFIFO underrun pending interrupt<br/>Write '1' to clear this interrupt.</p>      |
| 5              | R/W1C      | 0x0         | <p>TXO_INT<br/>TXFIFO Overrun Pending Interrupt<br/>0: No pending interrupt<br/>1: TXFIFO overrun pending interrupt<br/>Write '1' to clear this interrupt.</p>        |
| 4              | R          | 0x1         | <p>TXE_INT<br/>TXFIFO Empty Pending Interrupt<br/>0: No pending IRQ<br/>1: TXFIFO empty pending interrupt when data in TXFIFO are less than TX trigger level</p>      |
| 3              | /          | /           | /                                                                                                                                                                     |
| 2              | R/W1C      | 0x0         | <p>RXU_INT<br/>RXFIFO Underrun Pending Interrupt<br/>0: No pending interrupt<br/>1: RXFIFO underrun pending interrupt<br/>Write '1' to clear this interrupt.</p>      |
| 1              | R/W1C      | 0x0         | <p>RXO_INT<br/>RXFIFO Overrun Pending Interrupt<br/>0: No pending IRQ<br/>1: RXFIFO overrun pending IRQ<br/>Write '1' to clear this interrupt.</p>                    |
| 0              | R/W        | 0x0         | <p>RXA_INT<br/>RXFIFO Data Available Pending Interrupt<br/>0: No pending IRQ<br/>1: Data available pending IRQ when data in RXFIFO are more than RX trigger level</p> |

### 8.1.6.5 0x0010 I2S/PCM RXFIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: I2S/PCM_RXFIFO                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31:0           | R          | 0x0         | RX_DATA<br>RX Sample<br>The host can get one sample by reading this register. The left channel sample data is first and then the right channel sample. |

### 8.1.6.6 0x0014 I2S/PCM FIFO Control Register (Default Value: 0x0004\_00F0)

| Offset: 0x0014 |            |             | Register Name: I2S/PCM_FCTL                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 31             | R/W        | 0x0         | HUB_EN<br>Audio Hub Enable<br>The bit takes effect only when TXEN is set to 1.<br>I2S1/I2S2/OWA TXFIFO Hub Enable.<br>0: Disabled<br>1: Enabled |
| 30:26          | /          | /           | /                                                                                                                                               |
| 25             | R/WAC      | 0x0         | FTX<br>Write '1' to flush TXFIFO, self clear to '0'.                                                                                            |
| 24             | R/WAC      | 0x0         | FRX<br>Write '1' to flush RXFIFO, self clear to '0'.                                                                                            |
| 23:19          | /          | /           | /                                                                                                                                               |
| 18:12          | R/W        | 0x40        | TXTL<br>TXFIFO Empty Trigger Level<br>Interrupt and DMA request trigger level for TXFIFO normal condition.<br>Trigger Level = TXTL              |
| 11:10          | /          | /           | /                                                                                                                                               |
| 9:4            | R/W        | 0xF         | RXTL<br>RXFIFO Trigger Level<br>Interrupt and DMA request trigger level for RXFIFO normal condition.<br>Trigger Level = RXTL + 1                |
| 3              | /          | /           | /                                                                                                                                               |

| Offset: 0x0014 |            |             | Register Name: I2S/PCM_FCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2              | R/W        | 0x0         | <p>TXIM<br/>TXFIFO Input Mode (Mode 0, 1)<br/>0: Valid data at the MSB of TXFIFO register<br/>1: Valid data at the LSB of TXFIFO register<br/>Example for 20-bit transmitted audio sample:<br/>Mode 0: TXFIFO[31:0] = {APB_WDATA[31:12], 12'h0}<br/>Mode 1: TXFIFO[31:0] = {APB_WDATA[19:0], 12'h0}</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1:0            | R/W        | 0x0         | <p>RXOM<br/>RXFIFO Output Mode (Mode 0, 1, 2, 3)<br/>00: Expanding '0' at LSB of RXFIFO register<br/>01: Expanding received sample sign bit at MSB of RXFIFO register<br/>10: Truncating received samples at high half-word of RXFIFO register and low half-word of RXFIFO register is filled by '0'<br/>11: Truncating received samples at low half-word of RXFIFO register and high half-word of RXFIFO register is expanded by its sign bit<br/>Example for 20-bit received audio sample:<br/>Mode 0: APB_RDATA[31:0] = {RXFIFO[31:12], 12'h0}<br/>Mode 1: APB_RDATA[31:0] = {12{RXFIFO[31]}, RXFIFO[31:12]}<br/>Mode 2: APB_RDATA [31:0] = {RXFIFO[31:16], 16'h0}<br/>Mode 3: APB_RDATA[31:0] = {16{RXFIFO[31]}, RXFIFO[31:16]}</p> |

#### 8.1.6.7 0x0018 I2S/PCM FIFO Status Register (Default Value: 0x1080\_0080)

| Offset: 0x0018 |            |             | Register Name: I2S/PCM_FSTA                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:29          | /          | /           | /                                                                                                                                     |
| 28             | R          | 0x1         | <p>TXE<br/>TXFIFO Empty<br/>0: No room for new sample in TXFIFO<br/>1: More than one room for new sample in TXFIFO (&gt;= 1 Word)</p> |
| 27:24          | /          | /           | /                                                                                                                                     |
| 23:16          | R          | 0x80        | <p>TXE_CNT<br/>TXFIFO Empty Space Word Counter</p>                                                                                    |

| Offset: 0x0018 |            |             | Register Name: I2S/PCM_FSTA                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 15:9           | /          | /           | /                                                                                                          |
| 8              | R          | 0x0         | RXA<br>RXFIFO Available<br>0: No available data in RXFIFO<br>1: More than one sample in RXFIFO (>= 1 Word) |
| 7              | R          | 0x1         | PLACEHOLDER<br>NO Meaning.                                                                                 |
| 6:0            | R          | 0x0         | RXA_CNT<br>RXFIFO available sample word counter                                                            |

#### 8.1.6.8 0x001C I2S/PCM DMA & Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: I2S/PCM_INT                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                                                               |
| 7              | R/W        | 0x0         | TX_DRQ<br>TXFIFO Empty DRQ Enable<br>0: Disabled<br>1: Enabled                                                                                                  |
| 6              | R/W        | 0x0         | TXUI_EN<br>TXFIFO Underrun Interrupt Enable<br>0: Disabled<br>1: Enabled                                                                                        |
| 5              | R/W        | 0x0         | TXOI_EN<br>TXFIFO Overrun Interrupt Enable<br>0: Disabled<br>1: Enabled<br>When set to '1', an interrupt happens when writing new audio data if TXFIFO is full. |
| 4              | R/W        | 0x0         | TXEI_EN<br>TXFIFO Empty Interrupt Enable<br>0: Disabled<br>1: Enabled                                                                                           |

| Offset: 0x001C |            |             | Register Name: I2S/PCM_INT                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                |
| 3              | R/W        | 0x0         | <p>RX_DRQ<br/>RXFIFO Data Available DRQ Enable<br/>0: Disabled<br/>1: Enabled<br/>When set to '1', RXFIFO DMA request line is asserted if data is available in RXFIFO.</p> |
| 2              | R/W        | 0x0         | <p>RXUI_EN<br/>RXFIFO Underrun Interrupt Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                         |
| 1              | R/W        | 0x0         | <p>RXOI_EN<br/>RXFIFO Overrun Interrupt Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                          |
| 0              | R/W        | 0x0         | <p>RXAI_EN<br/>RXFIFO Data Available Interrupt Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                   |

#### 8.1.6.9 0x0020 I2S/PCM TXFIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: I2S/PCM_TXFIFO                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
| 31:0           | W          | 0x0         | <p>TX_DATA<br/>TX Sample<br/>Transmitting left, right channel sample data should be written to this register one by one. The left channel sample data is first and then the right channel sample.</p> |

#### 8.1.6.10 0x0024 I2S/PCM Clock Divide Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: I2S/PCM_CLKD |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:9           | /          | /           | /                           |

| Offset: 0x0024 |            |             | Register Name: I2S/PCM_CLKD                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8              | R/W        | 0x0         | <p>MCLKO_EN</p> <p>0: Disable MCLK Output</p> <p>1: Enable MCLK Output</p> <p><b>Note: Whether in slave or master mode, when this bit is set to '1', MCLK should be output.</b></p>                                                                                                                                                                                                                                                                                              |
| 7:4            | R/W        | 0x0         | <p>BCLKDIV</p> <p>BCLK Divide Ratio from PLL_AUDIO</p> <p>0000: Reserved</p> <p>0001: Divide by 1</p> <p>0010: Divide by 2</p> <p>0011: Divide by 4</p> <p>0100: Divide by 6</p> <p>0101: Divide by 8</p> <p>0110: Divide by 12</p> <p>0111: Divide by 16</p> <p>1000: Divide by 24</p> <p>1001: Divide by 32</p> <p>1010: Divide by 48</p> <p>1011: Divide by 64</p> <p>1100: Divide by 96</p> <p>1101: Divide by 128</p> <p>1110: Divide by 176</p> <p>1111: Divide by 192</p> |

| Offset: 0x0024 |            |             | Register Name: I2S/PCM_CLKD                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:0            | R/W        | 0x0         | <p>MCLKDIV</p> <p>MCLK Divide Ratio from PLL_AUDIO</p> <p>0000: Reserved</p> <p>0001: Divide by 1</p> <p>0010: Divide by 2</p> <p>0011: Divide by 4</p> <p>0100: Divide by 6</p> <p>0101: Divide by 8</p> <p>0110: Divide by 12</p> <p>0111: Divide by 16</p> <p>1000: Divide by 24</p> <p>1001: Divide by 32</p> <p>1010: Divide by 48</p> <p>1011: Divide by 64</p> <p>1100: Divide by 96</p> <p>1101: Divide by 128</p> <p>1110: Divide by 176</p> <p>1111: Divide by 192</p> |

#### 8.1.6.11 0x0028 I2S/PCM TX Sample Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: I2S/PCM_TXCNT                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:0           | R/W        | 0x0         | <p>TX_CNT</p> <p>TX Sample Counter</p> <p>The audio sample number of sending into TXFIFO. When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count on the base of this initial value.</p> |

### 8.1.6.12 0x002C I2S/PCM RX Sample Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: I2S/PCM_RXCNT                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | <p>RX_CNT<br/>RX Sample Counter</p> <p>The audio sample number of writing into RXFIFO. When one sample is written by Digital Audio Engine, the RX sample counter register increases by one. The RX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count on the base of this initial value.</p> |

### 8.1.6.13 0x0030 I2S/PCM Channel Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: I2S/PCM_CHCFG                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                          |
| 31:10          | /          | /           | /                                                                                                                                                                                                                                    |
| 9              | R/W        | 0x0         | <p>TX_SLOT_HIZ</p> <p>0: Normal mode for the last half-cycle of BCLK in the slot</p> <p>1: Turn to Hi-Z state for the last half-cycle of BCLK in the slot</p>                                                                        |
| 8              | R/W        | 0x0         | <p>TX_STATE</p> <p>0: Transfer level 0 in non-transferring slot</p> <p>1: Turn to Hi-Z State (TDM) in non-transferring slot</p>                                                                                                      |
| 7:4            | R/W        | 0x0         | <p>RX_SLOT_NUM</p> <p>RX Channel/Slot number between CPU/DMA and RXFIFO</p> <p>0000: 1 channel or slot</p> <p>...</p> <p>0111: 8 channels or slots</p> <p>1000: 9 channels or slots</p> <p>...</p> <p>1111: 16 channels or slots</p> |

| Offset: 0x0030 |            |             | Register Name: I2S/PCM_CHCFG                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | <p>TX_SLOT_NUM</p> <p>TX Channel/Slot number between CPU/DMA and TXFIFO</p> <p>0000: 1 channel or slot</p> <p>...</p> <p>0111: 8 channels or slots</p> <p>1000: 9 channels or slots</p> <p>...</p> <p>1111:16 channels or slots</p> |

#### 8.1.6.14 0x0034 I2S/PCM TX0 Channel Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: I2S/PCM_TX0CHSEL                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:22          | /          | /           | /                                                                                                                                                                                                                                 |
| 21:20          | R/W        | 0x0         | <p>TX0_OFFSET</p> <p>TX0 Offset Tune (TX0 Data offset to LRCK)</p> <p>0: No offset</p> <p>n: Data is offset by n BCLKs to LRCK</p>                                                                                                |
| 19:16          | R/W        | 0x0         | <p>TX0_CHSEL</p> <p>TX0 Channel (Slot) Number Select for Each Output</p> <p>0000: 1 channel or slot</p> <p>...</p> <p>0111: 8 channels or slots</p> <p>1000: 9 channels or slots</p> <p>...</p> <p>1111: 16 channels or slots</p> |
| 15:0           | R/W        | 0x0         | <p>TX0_CHEN</p> <p>TX0 Channel (Slot) Enable</p> <p>The bit[15:0] refer to Slot [15:0]. When one or more slots are disabled, the affected slots are set to the disable state.</p> <p>0: Disabled</p> <p>1: Enabled</p>            |

### 8.1.6.15 0x0038 I2S/PCM TX1 Channel Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: I2S/PCM_TX1CHSEL                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 31:22          | /          | /           | /                                                                                                                                                                                                            |
| 21:20          | R/W        | 0x0         | <p>TX1_OFFSET<br/>TX1 Offset Tune (TX1 Data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p>                                                                                    |
| 19:16          | R/W        | 0x0         | <p>TX1_CHSEL<br/>TX1 Channel (Slot) Number Select for Each Output<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111: 16 channels or slots</p> |
| 15:0           | R/W        | 0x0         | <p>TX1_CHEN<br/>TX1 Channel (Slot) Enable<br/>The bit[15:0] refers to Slot [15:0]. When one or more slots are disabled, the affected slots are set to the disable state.<br/>0: Disabled<br/>1: Enabled</p>  |

### 8.1.6.16 0x003C I2S/PCM TX2 Channel Select Register (Default Value: 0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: I2S/PCM_TX2CHSEL                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                               |
| 31:22          | /          | /           | /                                                                                                                         |
| 21:20          | R/W        | 0x0         | <p>TX2_OFFSET<br/>TX2 Offset Tune (TX2 Data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p> |

| Offset: 0x003C |            |             | Register Name: I2S/PCM_TX2CHSEL                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 19:16          | R/W        | 0x0         | <p>TX2_CHSEL</p> <p>TX2 Channel (Slot) Number Select for Each Output</p> <p>0000: 1 channel or slot</p> <p>...</p> <p>0111: 8 channels or slots</p> <p>1000: 9 channels or slots</p> <p>...</p> <p>1111: 16 channels or slots</p> |
| 15:0           | R/W        | 0x0         | <p>TX2_CHEN</p> <p>TX2 Channel (Slot) Enable</p> <p>The bit[15:0] refers to Slot [15:0]. When one or more slots are disabled, the affected slots are set to the disable state.</p> <p>0: Disabled</p> <p>1: Enabled</p>           |

#### 8.1.6.17 0x0040 I2S/PCM TX3 Channel Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: I2S/PCM_TX3CHSEL                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:22          | /          | /           | /                                                                                                                                                                                                                                 |
| 21:20          | R/W        | 0x0         | <p>TX3_OFFSET</p> <p>TX3 Offset Tune (TX3 Data offset to LRCK)</p> <p>0: No offset</p> <p>n: Data is offset by n BCLKs to LRCK</p>                                                                                                |
| 19:16          | R/W        | 0x0         | <p>TX3_CHSEL</p> <p>TX3 Channel (Slot) Number Select for Each Output</p> <p>0000: 1 channel or slot</p> <p>...</p> <p>0111: 8 channels or slots</p> <p>1000: 9 channels or slots</p> <p>...</p> <p>1111: 16 channels or slots</p> |

| Offset: 0x0040 |            |             | Register Name: I2S/PCM_TX3CHSEL                                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 15:0           | R/W        | 0x0         | <p>TX3_CHEN</p> <p>TX3 Channel (Slot) Enable</p> <p>The bit[15:0] refers to Slot [15:0]. When one or more slots are disabled, the affected slots are set to the disable state.</p> <p>0: Disabled</p> <p>1: Enabled</p> |

#### 8.1.6.18 0x0044 I2S/PCM TX0 Channel Mapping0 Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: I2S/PCM_TX0CHMAP0                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:28          | R/W        | 0x0         | <p>TX0_CH15_MAP</p> <p>TX0 Channel 15 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 27:24          | R/W        | 0x0         | <p>TX0_CH14_MAP</p> <p>TX0 Channel 14 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 23:20          | R/W        | 0x0         | <p>TX0_CH13_MAP</p> <p>TX0 Channel 13 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

| Offset: 0x0044 |            |             | Register Name: I2S/PCM_TX0CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 19:16          | R/W        | 0x0         | TX0_CH12_MAP<br>TX0 Channel 12 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 15:12          | R/W        | 0x0         | TX0_CH11_MAP<br>TX0 Channel 11 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX0_CH10_MAP<br>TX0 Channel 10 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX0_CH9_MAP<br>TX0 Channel 9 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample   |

| Offset: 0x0044 |            |             | Register Name: I2S/PCM_TX0CHMAP0                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 3:0            | R/W        | 0x0         | <p>TX0_CH8_MAP<br/>TX0 Channel 8 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |

#### 8.1.6.19 0x0048 I2S/PCM TX0 Channel Mapping1 Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: I2S/PCM_TX0CHMAP1                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31:28          | R/W        | 0x0         | <p>TX0_CH7_MAP<br/>TX0 Channel 7 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 27:24          | R/W        | 0x0         | <p>TX0_CH6_MAP<br/>TX0 Channel 6 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |

| Offset: 0x0048 |            |             | Register Name: I2S/PCM_TX0CHMAP1                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 23:20          | R/W        | 0x0         | <p>TX0_CH5_MAP</p> <p>TX0 Channel 5 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 19:16          | R/W        | 0x0         | <p>TX0_CH4_MAP</p> <p>TX0 Channel 4 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 15:12          | R/W        | 0x0         | <p>TX0_CH3_MAP</p> <p>TX0 Channel 3 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 11:8           | R/W        | 0x0         | <p>TX0_CH2_MAP</p> <p>TX0 Channel 2 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

| Offset: 0x0048 |            |             | Register Name: I2S/PCM_TX0CHMAP1                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 7:4            | R/W        | 0x0         | <p>TX0_CH1_MAP</p> <p>TX0 Channel 1 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 3:0            | R/W        | 0x0         | <p>TX0_CH0_MAP</p> <p>TX0 Channel 0 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

#### 8.1.6.20 0x004C I2S/PCM TX1 Channel Mapping0 Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: I2S/PCM_TX1CHMAP0                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:28          | R/W        | 0x0         | <p>TX1_CH15_MAP</p> <p>TX1 Channel 15 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

| Offset: 0x004C |            |             | Register Name: I2S/PCM_TX1CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 27:24          | R/W        | 0x0         | TX1_CH14_MAP<br>TX1 Channel 14 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX1_CH13_MAP<br>TX1 Channel 13 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX1_CH12_MAP<br>TX1 Channel 12 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 15:12          | R/W        | 0x0         | TX1_CH11_MAP<br>TX1 Channel 11 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x004C |            |             | Register Name: I2S/PCM_TX1CHMAP0                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 11:8           | R/W        | 0x0         | <p>TX1_CH10_MAP<br/>TX1 Channel 10 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 7:4            | R/W        | 0x0         | <p>TX1_CH9_MAP<br/>TX1 Channel 9 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p>   |
| 3:0            | R/W        | 0x0         | <p>TX1_CH8_MAP<br/>TX1 Channel 8 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p>   |

**8.1.6.21 0x0050 I2S/PCM TX1 Channel Mapping1 Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0050 |            |             | Register Name: I2S/PCM_TX1CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:28          | R/W        | 0x0         | TX1_CH7_MAP<br>TX1 Channel 7 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 27:24          | R/W        | 0x0         | TX1_CH6_MAP<br>TX1 Channel 6 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX1_CH5_MAP<br>TX1 Channel 5 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX1_CH4_MAP<br>TX1 Channel 4 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x0050 |            |             | Register Name: I2S/PCM_TX1CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 15:12          | R/W        | 0x0         | TX1_CH3_MAP<br>TX1 Channel 3 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX1_CH2_MAP<br>TX1 Channel 2 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX1_CH1_MAP<br>TX1 Channel 1 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 3:0            | R/W        | 0x0         | TX1_CHO_MAP<br>TX1 Channel 0 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

**8.1.6.22 0x0054 I2S/PCM TX2 Channel Mapping0 Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x0054 |            |             | Register Name: I2S/PCM_TX2CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:28          | R/W        | 0x0         | TX2_CH15_MAP<br>TX2 Channel 15 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 27:24          | R/W        | 0x0         | TX2_CH14_MAP<br>TX2 Channel 14 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX2_CH13_MAP<br>TX2 Channel 13 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX2_CH12_MAP<br>TX2 Channel 12 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x0054 |            |             | Register Name: I2S/PCM_TX2CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 15:12          | R/W        | 0x0         | TX2_CH11_MAP<br>TX2 Channel 11 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX2_CH10_MAP<br>TX2 Channel 10 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX2_CH9_MAP<br>TX2 Channel 9 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample   |
| 3:0            | R/W        | 0x0         | TX2_CH8_MAP<br>TX2 Channel 8 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample   |

**8.1.6.23 0x0058 I2S/PCM TX2 Channel Mapping1 Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0058 |            |             | Register Name: I2S/PCM_TX2CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:28          | R/W        | 0x0         | TX2_CH7_MAP<br>TX2 Channel 7 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 27:24          | R/W        | 0x0         | TX2_CH6_MAP<br>TX2 Channel 6 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX2_CH5_MAP<br>TX2 Channel 5 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX2_CH4_MAP<br>TX2 Channel 4 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x0058 |            |             | Register Name: I2S/PCM_TX2CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 15:12          | R/W        | 0x0         | TX2_CH3_MAP<br>TX2 Channel 3 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX2_CH2_MAP<br>TX2 Channel 2 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX2_CH1_MAP<br>TX2 Channel 1 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 3:0            | R/W        | 0x0         | TX2_CH0_MAP<br>TX2 Channel 0 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

**8.1.6.24 0x005C I2S/PCM TX3 Channel Mapping0 Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x005C |            |             | Register Name: I2S/PCM_TX3CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:28          | R/W        | 0x0         | TX3_CH15_MAP<br>TX3 Channel 15 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 27:24          | R/W        | 0x0         | TX3_CH14_MAP<br>TX3 Channel 14 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX3_CH13_MAP<br>TX3 Channel 13 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX3_CH12_MAP<br>TX3 Channel 12 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x005C |            |             | Register Name: I2S/PCM_TX3CHMAP0                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 15:12          | R/W        | 0x0         | TX3_CH11_MAP<br>TX3 Channel 11 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX3_CH10_MAP<br>TX3 Channel 10 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX3_CH9_MAP<br>TX3 Channel 9 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample   |
| 3:0            | R/W        | 0x0         | TX3_CH8_MAP<br>TX3 Channel 8 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample   |

**8.1.6.25 0x0060 I2S/PCM TX3 Channel Mapping1 Register 1 (Default Value: 0x0000\_0000)**

| Offset: 0x0060 |            |             | Register Name: I2S/PCM_TX3CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:28          | R/W        | 0x0         | TX3_CH7_MAP<br>TX3 Channel 7 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 27:24          | R/W        | 0x0         | TX3_CH6_MAP<br>TX3 Channel 6 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 23:20          | R/W        | 0x0         | TX3_CH5_MAP<br>TX3 Channel 5 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 19:16          | R/W        | 0x0         | TX3_CH4_MAP<br>TX3 Channel 4 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

| Offset: 0x0060 |            |             | Register Name: I2S/PCM_TX3CHMAP1                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 15:12          | R/W        | 0x0         | TX3_CH3_MAP<br>TX3 Channel 3 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 11:8           | R/W        | 0x0         | TX3_CH2_MAP<br>TX3 Channel 2 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 7:4            | R/W        | 0x0         | TX3_CH1_MAP<br>TX3 Channel 1 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |
| 3:0            | R/W        | 0x0         | TX3_CHO_MAP<br>TX3 Channel 0 Mapping<br>0000: The first sample<br>...<br>0111: The eighth sample<br>1000: The ninth sample<br>...<br>1111: The sixteenth sample |

### 8.1.6.26 0x0064 I2S/PCM RX Channel Select Register (Default Value: 0x0000\_0000)

| Offset: 0x0064 |            |             | Register Name: I2S/PCM_RXCHSEL                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:22          | /          | /           | /                                                                                                                                                                                                    |
| 21:20          | R/W        | 0x0         | <p>RX_OFFSET<br/>RX Offset Tune (RX Data offset to LRCK)<br/>0: No offset<br/>n: Data is offset by n BCLKs to LRCK</p>                                                                               |
| 19:16          | R/W        | 0x0         | <p>RX_CHSEL<br/>RX Channel (Slot) Number Select for Input<br/>0000: 1 channel or slot<br/>...<br/>0111: 8 channels or slots<br/>1000: 9 channels or slots<br/>...<br/>1111: 16 channels or slots</p> |
| 15:0           | /          | /           | /                                                                                                                                                                                                    |

### 8.1.6.27 0x0068 I2S/PCM RX Channel Mapping Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: I2S/PCM_RXCHMAPO                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:30          | /          | /           | /                                                                                                  |
| 29:28          | R/W        | 0x0         | <p>RX_CH15_SELECT<br/>RX Channel 15 Select<br/>00: SDI0<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p> |

| Offset: 0x0068 |            |             | Register Name: I2S/PCM_RXCHMAP0                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 27:24          | R/W        | 0x0         | <p>RX_CH15_MAP<br/>RX Channel 15 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 23:22          | /          | /           | /                                                                                                                                                                             |
| 21:20          | R/W        | 0x0         | <p>RX_CH14_SELECT<br/>RX Channel 14 Select<br/>00: SDI0<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |
| 19:16          | R/W        | 0x0         | <p>RX_CH14_MAP<br/>RX Channel 14 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 15:14          | /          | /           | /                                                                                                                                                                             |
| 13:12          | R/W        | 0x0         | <p>RX_CH13_SELECT<br/>RX Channel 13 Select<br/>00: SDI0<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |

| Offset: 0x0068 |            |             | Register Name: I2S/PCM_RXCHMAP0                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 11:8           | R/W        | 0x0         | <p>RX_CH13_MAP</p> <p>RX Channel 13 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 7:6            | /          | /           | /                                                                                                                                                                                                  |
| 5:4            | R/W        | 0x0         | <p>RX_CH12_SELECT</p> <p>RX Channel 12 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                  |
| 3:0            | R/W        | 0x0         | <p>RX_CH12_MAP</p> <p>RX Channel 12 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

#### 8.1.6.28 0x006C I2S/PCM RX Channel Mapping Register1 (Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: I2S/PCM_RXCHMAP1                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                 |
| 29:28          | R/W        | 0x0         | <p>RX_CH11_SELECT</p> <p>RX Channel 11 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p> |

| Offset: 0x006C |            |             | Register Name: I2S/PCM_RXCHMAP1                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 27:24          | R/W        | 0x0         | <p>RX_CH11_MAP</p> <p>RX Channel 11 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 23:22          | /          | /           | /                                                                                                                                                                                                  |
| 21:20          | R/W        | 0x0         | <p>RX_CH10_SELECT</p> <p>RX Channel 10 Select</p> <p>00: SDIO</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                  |
| 19:16          | R/W        | 0x0         | <p>RX_CH10_MAP</p> <p>RX Channel 10 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 15:14          | /          | /           | /                                                                                                                                                                                                  |
| 13:12          | R/W        | 0x0         | <p>RX_CH9_SELECT</p> <p>RX Channel 9 Select</p> <p>00: SDIO</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                    |

| Offset: 0x006C |            |             | Register Name: I2S/PCM_RXCHMAP1                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 11:8           | R/W        | 0x0         | <p>RX_CH9_MAP</p> <p>RX Channel 9 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 7:6            | /          | /           | /                                                                                                                                                                                                |
| 5:4            | R/W        | 0x0         | <p>RX_CH8_SELECT</p> <p>RX Channel 8 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                  |
| 3:0            | R/W        | 0x0         | <p>RX_CH8_MAP</p> <p>RX Channel 8 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

#### 8.1.6.29 0x0070 I2S/PCM RX Channel Mapping Register2 (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: I2S/PCM_RXCHMAP2                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31:30          | /          | /           | /                                                                                                               |
| 29:28          | R/W        | 0x0         | <p>RX_CH7_SELECT</p> <p>RX Channel 7 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p> |

| Offset: 0x0070 |            |             | Register Name: I2S/PCM_RXCHMAP2                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 27:24          | R/W        | 0x0         | <p>RX_CH7_MAP<br/>RX Channel 7 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 23:22          | /          | /           | /                                                                                                                                                                           |
| 21:20          | R/W        | 0x0         | <p>RX_CH6_SELECT<br/>RX Channel 6 Select<br/>00: SDI0<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |
| 19:16          | R/W        | 0x0         | <p>RX_CH6_MAP<br/>RX Channel 6 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 15:14          | /          | /           | /                                                                                                                                                                           |
| 13:12          | R/W        | 0x0         | <p>RX_CH5_SELECT<br/>RX Channel 5 Select<br/>00: SDI0<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |

| Offset: 0x0070 |            |             | Register Name: I2S/PCM_RXCHMAP2                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 11: 8          | R/W        | 0x0         | <p>RX_CH5_MAP</p> <p>RX Channel 5 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 7:6            | /          | /           | /                                                                                                                                                                                                |
| 5:4            | R/W        | 0x0         | <p>RX_CH4_SELECT</p> <p>RX Channel 4 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                  |
| 3:0            | R/W        | 0x0         | <p>RX_CH4_MAP</p> <p>RX Channel 4 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

#### 8.1.6.30 0x0074 I2S/PCM RX Channel Mapping Register3 (Default Value: 0x0000\_0000)

| Offset: 0x0074 |            |             | Register Name: I2S/PCM_RXCHMAP3                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                     |
| 31:30          | /          | /           | /                                                                                                               |
| 29:28          | R/W        | 0x0         | <p>RX_CH3_SELECT</p> <p>RX Channel 3 Select</p> <p>00: SDI0</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p> |

| Offset: 0x0074 |            |             | Register Name: I2S/PCM_RXCHMAP3                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 27:24          | R/W        | 0x0         | <p>RX_CH3_MAP<br/>RX Channel 3 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 23:22          | /          | /           | /                                                                                                                                                                           |
| 21:20          | R/W        | 0x0         | <p>RX_CH2_SELECT<br/>RX Channel 2 Select<br/>00: SDIO<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |
| 19:16          | R/W        | 0x0         | <p>RX_CH2_MAP<br/>RX Channel 2 Mapping<br/>0000: The first sample<br/>...<br/>0111: The eighth sample<br/>1000: The ninth sample<br/>...<br/>1111: The sixteenth sample</p> |
| 15:14          | /          | /           | /                                                                                                                                                                           |
| 13:12          | R/W        | 0x0         | <p>RX_CH1_SELECT<br/>RX Channel 1 Select<br/>00: SDIO<br/>01: SDI1<br/>10: SDI2<br/>11: SDI3</p>                                                                            |

| Offset: 0x0074 |            |             | Register Name: I2S/PCM_RXCHMAP3                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 11:8           | R/W        | 0x0         | <p>RX_CH1_MAP</p> <p>RX Channel 1 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |
| 7:6            | /          | /           | /                                                                                                                                                                                                |
| 5:4            | R/W        | 0x0         | <p>RX_CHO_SELECT</p> <p>RX Channel 0 Select</p> <p>00: SDIO</p> <p>01: SDI1</p> <p>10: SDI2</p> <p>11: SDI3</p>                                                                                  |
| 3:0            | R/W        | 0x0         | <p>RX_CHO_MAP</p> <p>RX Channel 0 Mapping</p> <p>0000: The first sample</p> <p>...</p> <p>0111: The eighth sample</p> <p>1000: The ninth sample</p> <p>...</p> <p>1111: The sixteenth sample</p> |

#### 8.1.6.31 0x0080 I2S/PCM ASRC MCLK Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: MCLKCFG                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:17          | R          | 0x0         | /                                                                                               |
| 16             | R/W        | 0x0         | <p>ASRC_MCLK_GATE</p> <p>ASRC Clock Gate Enable Control</p> <p>0: Gated</p> <p>1: Not gated</p> |
| 15:4           | /          | /           | /                                                                                               |

| Offset: 0x0080 |            |             | Register Name: MCLKCFG                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3:0            | R/W        | 0x0         | <p>ASRC_MCLK_FREQ_DIV_COE</p> <p>Frequency Division Coefficient</p> <p>4'd0 = Res (no output),</p> <p>4'd1 = 1x,</p> <p>4'd2 = 1/2x,</p> <p>4'd3 = 1/4x,</p> <p>4'd4 = 1/6x,</p> <p>4'd5 = 1/8x,</p> <p>4'd6 = 1/12x,</p> <p>4'd7 = 1/16x,</p> <p>4'd8 = 1/24x,</p> <p>4'd9 = 1/32x,</p> <p>4'd10 = 1/48,</p> <p>4'd11 = 1/64x,</p> <p>4'd12 = 1/96x,</p> <p>4'd13 = 1/128x,</p> <p>4'd14 = 1/176x,</p> <p>4'd15 = 1/192x,</p> <p>others = Res</p> |

#### 8.1.6.32 0x0084 I2S/PCM ASRC OUT Sample Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: FSOUTCFG                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:21          | R          | 0x0         | /                                                                                            |
| 20             | R/W        | 0x0         | <p>FSOUT_GATE</p> <p>fsout Clock Gate Enable Control</p> <p>0: Gated</p> <p>1: Not gated</p> |

| Offset: 0x0084 |            |             | Register Name: FSOUTCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19:16          | R/W        | 0x0         | <p>FSOUT_CLK_SRC_SEL<br/>fsout Clock Source Select</p> <p>00: I2S0_ASRC_CLK<br/>01: ACLK<br/>10: ACLKM<br/>11: BCLK<br/>Others: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | <p>FSOUT_CLK_FREQ_DIV_COE1<br/>fsout Frequency Division Coefficient 1<br/>The First Division Factor</p> <p>It has two levels of frequency division, the first level is bit[7:4], the second level is bit[3:0], and the frequency division factors are multiplied by the two division factors, the division relationship of the two divisions are the same.</p> <p>4'd0 = Res (no output),<br/>         4'd1 = 1x,<br/>         4'd2 = 1/2x,<br/>         4'd3 = 1/4x,<br/>         4'd4 = 1/6x,<br/>         4'd5 = 1/8x,<br/>         4'd6 = 1/12x,<br/>         4'd7 = 1/16x,<br/>         4'd8 = 1/24x,<br/>         4'd9 = 1/32x,<br/>         4'd10 = 1/48,<br/>         4'd11 = 1/64x,<br/>         4'd12 = 1/96x,<br/>         4'd13 = 1/128x,<br/>         4'd14 = 1/176x,<br/>         4'd15 = 1/192x</p> |

| Offset: 0x0084 |            |             | Register Name: FsoutCFG                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0            | R/W        | 0x0         | <p>FSOUT_CLK_FREQ_DIV_COE2<br/>fsout Frequency Division Coefficient 2</p> <p>The Second Division Factor</p> <p>4'd0 = Res (no output),<br/>4'd1 = 1x,<br/>4'd2 = 1/2x,<br/>4'd3 = 1/4x,<br/>4'd4 = 1/6x,<br/>4'd5 = 1/8x,<br/>4'd6 = 1/12x,<br/>4'd7 = 1/16x,<br/>4'd8 = 1/24x,<br/>4'd9 = 1/32x,<br/>4'd10 = 1/48,<br/>4'd11 = 1/64x,<br/>4'd12 = 1/96x,<br/>4'd13 = 1/128x,<br/>4'd14 = 1/176x,<br/>4'd15 = 1/192x</p> |

#### 8.1.6.33 0x0088 I2S/PCM IN Sample Pulse Extend Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: FsinEXTCFG                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:17          | R          | 0x0         | /                                                                                             |
| 16             | R/W        | 0x0         | <p>Extend Enable</p> <p>0: Disabled<br/>1: Enabled</p> <p>Enable the bit when using ASRC.</p> |
| 15:0           | R/W        | 0x0         | <p>The Cycle Number of Pulse Extend</p> <p>The cycle is BCLK clock and is 1 at least.</p>     |

### 8.1.6.34 0x008C I2S/PCM ASRC Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x008C |            |             | Register Name: ASRCEN                             |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 31:1           | R          | 0x0         | /                                                 |
| 0              | R/W        | 0x0         | ASRC Function Enable<br>0: Disabled<br>1: Enabled |

### 8.1.6.35 0x0090 I2S/PCM ASRC Manual Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: ASRCMANCFG                                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                              |
| 31             | R/W        | 0x0         | ASRC_RATIO_MANUAL_EN<br>Manual Configuration of ASRC Ratio Enable<br>0: Disabled<br>1: Enabled                                                                                                                                                           |
| 30:26          | R          | 0x0         | /                                                                                                                                                                                                                                                        |
| 25:0           | R/W        | 0x0         | ASRC_RATIO_VALUE_MANUAL_CFG<br>ASRC Ratio Value Manual Configure<br>The ratio value is an unsigned 26-bit number and uses 4.22 data format, which means there are 4 bits to the left of the decimal point and 22 bits to the right of the decimal point. |

### 8.1.6.36 0x0094 I2S/PCM ASRC Ratio State Register (Default Value: 0x0040\_0000)

| Offset: 0x0094 |            |             | Register Name: ASRCRATIOSTAT                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:30          | R          | 0x0         | /                                                                                                                                       |
| 29             | R          | 0x0         | ASRC_BUF_OVERFLOW_STA<br>ASRC Receive Data Buffer Overflow State<br>It can control the mute with lock.<br>0: No overflow<br>1: Overflow |

| Offset: 0x0094 |            |             | Register Name: ASRCRATIOSTAT                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 28             | R          | 0x0         | <p>ADAPT_COMPUT_LOCK<br/>Adaptive Ratio Computational Lock</p> <p>0: Unlocked<br/>1: Locked</p> |
| 27:26          | R          | 0x0         | /                                                                                               |
| 25:0           | R          | 0x400000    | <p>ADAPT_COMPUT_VALUE<br/>Adaptive Ratio Computational Value</p>                                |

#### 8.1.6.37 0x0098 I2S/PCM ASRC FIFO State Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: ASRCFIFOSTAT                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:9           | /          | /           | /                                                                                                                                                   |
| 8:0            | R          | 0x0         | <p>ASRC_RX_FIFO_FULL_LEVEL<br/>ASRC RX FIFO Full Level</p> <p>The manually-configured FIFO fill level for the ratio value of the received data.</p> |

#### 8.1.6.38 0x009C I2S/PCM MBIST Test Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: ASRCMBISTCFG                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:9           | /          | /           | /                                                                            |
| 8              | R/W        | 0x0         | <p>ASRC_RAM_BIST_EN<br/>ASRC RAM BIST Enable</p> <p>Enable the RAM BIST.</p> |
| 7:1            | /          | /           | /                                                                            |
| 0              | R/W        | 0x0         | <p>ASRC_ROM_BIST_EN<br/>ASRC ROM BIST Enable</p> <p>Enable the ROM BIST.</p> |

**8.1.6.39 0x00A0 I2S/PCM ASRC MBIST Test State Register (Default Value: 0x0000\_0002)**

| Offset: 0x00A0 |            |             | Register Name: ASRCMBISTSTA                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:19          | /          | /           | /                                                                        |
| 18             | R          | 0x0         | ROM_BIST_ERROR_XOR<br>ROM BIST error xor                                 |
| 17             | R          | 0x0         | ROM_BIST_ERROR_SUM<br>ROM BIST error sum                                 |
| 16             | R          | 0x0         | ROM_BUSY_STATUS<br>ROM BUSY STATUS<br>1: ROM busy<br>0: ROM idle         |
| 15:8           | /          | /           | /                                                                        |
| 7              | R          | 0x0         | RAM_BIST_ERR_STATUS<br>RAM BIST error status<br>1: Error<br>0: No effect |
| 6:4            | R          | 0x0         | RAM_BIST_ERROR_PATTERN.<br>RAM BIST error pattern                        |
| 3:2            | R          | 0x0         | RAM_BIST_ERROR_CYCLE<br>RAM BIST error cycle                             |
| 1              | R          | 0x1         | RAM_STOP_STATUS<br>RAM stop status<br>1: Stop<br>0: Running              |
| 0              | R          | 0x0         | RAM_BUSY_STATUS<br>RAM busy status<br>1: RAM busy<br>0: RAM idle         |

## 8.2 DMIC

### 8.2.1 Overview

The DMIC controller supports one 8-channel digital microphone interface and can output 128 fs or 64 fs (fs = ADC sample rate).

The DMIC controller includes the following features:

- Supports up to 8 channels
- Sample rate from 8 kHz to 48 kHz

### 8.2.2 Block Diagram

The following figure shows a block diagram of the DMIC.

Figure 8-12 DMIC Block Diagram



### 8.2.3 Functional Description

#### 8.2.3.1 External Signals

The following table describes the external signals of DMIC.

**Table 8-5 DMIC External Signals**

| <b>Signal</b> | <b>Description</b>              | <b>Type</b> |
|---------------|---------------------------------|-------------|
| DMIC-CLK      | Digital Microphone Clock Output | O           |
| DMIC-DATA0    | Digital Microphone Data Input   | I           |
| DMIC-DATA1    | Digital Microphone Data Input   | I           |
| DMIC-DATA2    | Digital Microphone Data Input   | I           |
| DMIC-DATA3    | Digital Microphone Data Input   | I           |

### 8.2.3.2 Clock Sources

The following table describes the clock source for DMIC. For clock setting, configurations, and gating information, refer to section 3.3 “[CCU](#)”.

**Table 8-6 DMIC Clock Sources**

| <b>Clock Sources</b> | <b>Description</b>                                                    |
|----------------------|-----------------------------------------------------------------------|
| PLL_AUDIO0(1X)       | By default, PLL_AUDIO0(1X) is 24.5714 MHz.                            |
| PLL_AUDIO1(DIV2)     | By default, PLL_AUDIO1 is 3072 MHz, PLL_AUDIO1(DIV2) is 1536 MHz, and |
| PLL_AUDIO1(DIV5)     | PLL_AUDIO1(DIV5) is 614.4 MHz (24.576 MHz*25).                        |

### 8.2.3.3 Operation Mode

The software operation of the DMIC is divided into five steps: system setup, DMIC initialization, channel setup, DMA setup, and Enable/Disable module.

The following figure shows the flow chart of the whole operation, the system setup, and the DMIC initialization.

Figure 8-13 DMIC Operation Mode



### 1. System Setup and DMIC Initialization

The first step in the system setup is properly programming the GPIO because the DMIC port is a multiplex pin. For functions of the multiplex pins, refer to the pin multiplex specification.

Perform the following steps for the clock source. Firstly, disable the PLL\_AUDIO through [PLL\\_AUDIOx Control Register](#)[PLL\_ENABLE]. Secondly, set up the frequency of the PLL\_AUDIO in [PLL\\_AUDIOx Control Register](#). Then enable PLL\_AUDIO. After that, enable the DMIC gating through [DMIC CLK REG](#) when you checkout that the LOCK bit of [PLL\\_AUDIOx Control Register](#) becomes 1. At last, reset and enable the DMIC bus gating by [DMIC BGR REG](#).

After the system setup, the register of DMIC can be setup. Firstly, initialize the DMIC. You should close the globe enable bit ([DMIC EN](#)[8]), data channel enable bit ([DMIC EN](#)[7:0]) by writing 0 to it. After that, flush the RXFIFO by writing 1 to [DMIC\\_RXFIFO\\_CTR](#)[31]. At last, you can clear the Data/RXFIFO counter by writing 1 to [DMIC\\_RXFIFO\\_STA](#), [DMIC\\_CNT](#).

### 2. Channel Setup and DMA Setup

You can set up the sample rate, the sample resolution, the over-sample rate, the channel number, the RXFIFO output mode, the RXFIFO trigger level, and so on. The setup of the register can be found in the specification.

The DMIC supports two methods to transfer the data. The most common way is DMA, the setup of DMA can be found in section 3.9 “[DMAC](#)”. In this module, you just enable the DRQ.

### 3. Enable and Disable DMIC

To enable the function, you can enable the data channel enable bit ([DMIC\\_EN](#)[7:0]) by writing 1 to it. After that, enable DMIC by writing 1 to the Globe Enable bit ([DMIC\\_EN](#)[8]). Write 0 to [DMIC\\_EN](#)[8] to disable DMIC.

### 8.2.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| DMIC        | 0x02031000   |

| Register Name       | Offset | Description                              |
|---------------------|--------|------------------------------------------|
| DMIC_EN             | 0x0000 | DMIC Enable Control Register             |
| DMIC_SR             | 0x0004 | DMIC Sample Rate Register                |
| DMIC_CTR            | 0x0008 | DMIC Control Register                    |
| DMIC_DATA           | 0x0010 | DMIC Data Register                       |
| DMIC_INTC           | 0x0014 | MIC Interrupt Control Register           |
| DMIC_INTS           | 0x0018 | DMIC Interrupt Status Register           |
| DMIC_RXFIFO_CTR     | 0x001C | DMIC RXFIFO Control Register             |
| DMIC_RXFIFO_STA     | 0x0020 | DMIC RXFIFO Status Register              |
| DMIC_CH_NUM         | 0x0024 | DMIC Channel Numbers Register            |
| DMIC_CH_MAP         | 0x0028 | DMIC Channel Mapping Register            |
| DMIC_CNT            | 0x002C | DMIC Counter Register                    |
| DATA0_DATA1_VOL_CTR | 0x0030 | Data0 and Data1 Volume Control Register  |
| DATA2_DATA3_VOL_CTR | 0x0034 | Data2 And Data3 Volume Control Register  |
| HPF_EN_CTR          | 0x0038 | High Pass Filter Enable Control Register |
| HPF_COEF_REG        | 0x003C | High Pass Filter Coefficient Register    |
| HPF_GAIN_REG        | 0x0040 | High Pass Filter Gain Register           |

### 8.2.5 Register Description

#### 8.2.5.1 0x0000 DMIC Enable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            | Register Name: DMIC_EN |             |
|----------------|------------|------------------------|-------------|
| Bit            | Read/Write | Default/Hex            | Description |
| 31:30          | /          | /                      | /           |

| Offset: 0x0000 |            |             | Register Name: DMIC_EN                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 29             | R/W        | 0x0         | <b>RX_SYNC_EN_START</b><br>Audio Subsys RX Synchronize Enable Start<br>Includes Audio codec/I2S1/I2S2/DMIC<br>The bit takes effect only when RX_SYNC_EN is set to 1.<br>0: Disabled<br>1: Enabled |
| 28             | R/W        | 0x0         | <b>RX_SYNC_EN</b><br>DMIC RX Synchronize Enable<br>0: Disabled<br>1: Enabled                                                                                                                      |
| 27:9           | /          | /           | /                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | <b>GLOBE_EN</b><br>DMIC Globe Enable<br>0: Disabled<br>1: Enabled                                                                                                                                 |
| 7              | R/W        | 0x0         | <b>DATA3_CHR_EN</b><br>DATA3 Right Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                                    |
| 6              | R/W        | 0x0         | <b>DATA3_CHL_EN</b><br>DATA3 Left Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                                     |
| 5              | R/W        | 0x0         | <b>DATA2_CHR_EN</b><br>DATA2 Right Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                                    |
| 4              | R/W        | 0x0         | <b>DATA2_CHL_EN</b><br>DATA2 Left Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                                     |
| 3              | R/W        | 0x0         | <b>DATA1_CHR_EN</b><br>DATA1 Right Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                                    |

| Offset: 0x0000 |            |             | Register Name: DMIC_EN                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 2              | R/W        | 0x0         | DATA1_CHL_EN<br>DATA1 Left Channel Enable<br>0: Disabled<br>1: Enabled  |
| 1              | R/W        | 0x0         | DATA0_CHR_EN<br>DATA0 Right Channel Enable<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | DATA0_CHL_EN<br>DATA0 Left Channel Enable<br>0: Disabled<br>1: Enabled  |

### 8.2.5.2 0x0004 DMIC Sample Rate Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: DMIC_SR                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                       |
| 2:0            | R/W        | 0x0         | DMIC_SR<br>Sample Rate of DMIC<br>000: 48 kHz<br>010: 24 kHz<br>100: 12 kHz<br>110: Reserved<br>001: 32 kHz<br>011: 16 kHz<br>101: 8 kHz<br>111: Reserved<br>44.1 kHz/22.05 kHz/11.025 kHz can be supported by Audio PLL Configure Bit. |

### 8.2.5.3 0x0008 DMIC Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: DMIC_CTR                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:11          | /          | /           | /                                                                                                                    |
| 10:9           | R/W        | 0x0         | DMICFDT<br>DMIC RXFIFO Delay Time for Writing Data after GLOBE_EN<br>00: 5 ms<br>01: 10 ms<br>10: 20 ms<br>11: 30 ms |
| 8              | R/W        | 0x0         | DMICDFEN<br>DMIC RXFIFO Delay Function for Writing Data after GLOBE_EN<br>0: Disabled<br>1: Enabled                  |
| 7              | R/W        | 0x0         | DATA3 Left Data and Right Data Swap Enable<br>0: Disabled<br>1: Enabled                                              |
| 6              | R/W        | 0x0         | DATA2 Left Data and Right Data Swap Enable<br>0: Disabled<br>1: Enabled                                              |
| 5              | R/W        | 0x0         | DATA1 Left Data and Right Data Swap Enable<br>0: Disabled<br>1: Enabled                                              |
| 4              | R/W        | 0x0         | DATA0 Left Data and Right Data Swap Enable<br>0: Disabled<br>1: Enabled                                              |
| 3:1            | /          | /           | /                                                                                                                    |
| 0              | R/W        | 0x0         | DMIC Oversample Rate<br>0: 128 (Supports 8 kHz to 24 kHz)<br>1: 64 (Supports 16 kHz to 48 kHz)                       |

### 8.2.5.4 0x0010 DMIC DATA Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: DMIC_DATA |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | R          | 0x0         | DMIC_DATA                |

### 8.2.5.5 0x0014 DMIC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: DMIC_INTC                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:3           | /          | /           | /                                                                                           |
| 2              | R/W        | 0x0         | <b>RXFIFO_DRQ_EN</b><br>DMIC RXFIFO Data Available DRQ Enable<br>0: Disabled<br>1: Enabled  |
| 1              | R/W        | 0x0         | <b>RXFIFO_OVERRUN_IRQ_EN</b><br>DMIC RXFIFO Overrun IRQ Enable<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | <b>DATA_IRQ_EN</b><br>DMIC RXFIFO Data Available IRQ Enable<br>0: Disabled<br>1: Enabled    |

### 8.2.5.6 0x0018 DMIC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: DMIC_INTS                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                          |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                    |
| 1              | R/W1C      | 0x0         | <b>RXFIFO_OVERRUN_IRQ_PENDING</b><br>DMIC RXFIFO Overrun Pending Interrupt<br>0: No pending IRQ<br>1: RXFIFO overrun pending IRQ<br>Writing '1' to clear this interrupt or automatically clear if the interrupt condition fails.     |
| 0              | R/W1C      | 0x0         | <b>RXFIFO_DATA_IRQ_PENDING</b><br>DMIC RXFIFO Data Available Pending Interrupt<br>0: No pending IRQ<br>1: Data available pending IRQ<br>Writing '1' to clear this interrupt or automatically clear if the interrupt condition fails. |

### 8.2.5.7 0x001C DMIC RXFIFO Control Register (Default Value: 0x0000\_0040)

| Offset: 0x001C |            |             | Register Name: DMIC_RXFIFO_CTR                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31             | R/W1C      | 0x0         | DMIC_RXFIFO_FLUSH<br>DMIC RXFIFO Flush<br>Writing '1' to flush RXFIFO, self clear to '0'                                                                                                                                                                                                                                                                                                                                                                                    |
| 30:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 9              | R/W        | 0x0         | RXFIFO_MODE<br>RXFIFO Output Mode (Mode 0, 1)<br>0: Expanding '0' at LSB of RXFIFO register<br>1: Expanding received sample sign bit at MSB of RXFIFO register<br>For 24-bit received audio sample:<br>Mode 0: RXDATA[31:0] = {RXFIFO_O[20:0], 11'h0}<br>Mode 1: RXDATA[31:0] = {8{RXFIFO_O[20]}, RXFIFO_O[20:0], 3'h0}<br>For 16-bit received audio sample:<br>Mode 0: RXDATA[31:0] = {RXFIFO_O[20:5], 16'h0}<br>Mode 1: RXDATA[31:0] = {16{RXFIFO_O[20]}, RXFIFO_O[20:5]} |
| 8              | R/W        | 0x0         | Sample_Resolution<br>0: 16-bit<br>1: 24- bit                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0            | R/W        | 0x40        | RXFIFO_TRG_LEVEL<br>RXFIFO Trigger Level (TRLV[7:0])<br>Interrupt and DMA request trigger level for DMIC RXFIFO normal condition IRQ/DRQ Generated when WLEVEL > TRLV[7:0]<br>WLEVEL represents the number of valid samples in the DMIC RXFIFO                                                                                                                                                                                                                              |

### 8.2.5.8 0x0020 DMIC RXFIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: DMIC_RXFIFO_STA |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:9           | /          | /           | /                              |
| 8              | R          | 0x1         | Reserved                       |

| Offset: 0x0020 |            |             | Register Name: DMIC_RXFIFO_STA                             |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 7:0            | R/W        | 0x0         | DMIC_DATA_CNT<br>DMIC RXFIFO Available Sample Word Counter |

#### 8.2.5.9 0x0024 DMIC Channel Numbers Register (Default Value: 0x0000\_0001)

| Offset: 0x0024 |            |             | Register Name: DMIC_CH_NUM                              |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:3           | /          | /           | /                                                       |
| 2:0            | R/W        | 0x1         | DMIC_CH_NUM<br>DMIC enable channel numbers are (N + 1). |

#### 8.2.5.10 0x0028 DMIC Channel Mapping Register (Default Value: 0x7654\_3210)

| Offset: 0x0028 |            |             | Register Name: DMIC_CH_MAP                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                |
| 31:28          | R/W        | 0x7         | DMIC_CH7_MAP<br>DMIC Channel 7 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |

| Offset: 0x0028 |            |             | Register Name: DMIC_CH_MAP                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                |
| 27:24          | R/W        | 0x6         | DMIC_CH6_MAP<br>DMIC Channel 6 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 23:20          | R/W        | 0x5         | DMIC_CH5_MAP<br>DMIC Channel 5 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 19:16          | R/W        | 0x4         | DMIC_CH4_MAP<br>DMIC Channel 4 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |

| Offset: 0x0028 |            |             | Register Name: DMIC_CH_MAP                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                |
| 15:12          | R/W        | 0x3         | DMIC_CH3_MAP<br>DMIC Channel 3 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 11:8           | R/W        | 0x2         | DMIC_CH2_MAP<br>DMIC Channel 2 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |
| 7:4            | R/W        | 0x1         | DMIC_CH1_MAP<br>DMIC Channel 1 Mapping<br>0000: DATA0 Left Channel<br>0001: DATA0 Right Channel<br>0010: DATA1 Left Channel<br>0011: DATA1 Right Channel<br>0100: DATA2 Left Channel<br>0101: DATA2 Right Channel<br>0110: DATA3 Left Channel<br>0111: DATA3 Right Channel |

| Offset: 0x0028 |            |             | Register Name: DMIC_CH_MAP                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                               |
| 3:0            | R/W        | 0x0         | <p>DMIC_CH0_MAP<br/>DMIC Channel0 Mapping<br/>0000: DATA0 Left Channel<br/>0001: DATA0 Right Channel<br/>0010: DATA1 Left Channel<br/>0011: DATA1 Right Channel<br/>0100: DATA2 Left Channel<br/>0101: DATA2 Right Channel<br/>0110: DATA3 Left Channel<br/>0111: DATA3 Right Channel</p> |

#### 8.2.5.11 0x002C DMIC Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: DMIC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:0           | R/W        | 0x0         | <p>DMIC_CNT<br/>RX Sample Counter<br/>The audio sample number of writing into RXFIFO. When one sample is read by Digital Audio Engine, the RX sample counter register increases by one. The RX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count on the base of this initial value.</p> <p><b>Note:</b> It is used for Audio/Video Synchronization.</p> |

**8.2.5.12 0x0030 DATA0 and DATA1 Volume Control Register (Default Value: 0xA0A0\_A0A0)**

| Offset: 0x0030 |            |             | Register Name: DATA0_DATA1_VOL_CTR                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:24          | R/W        | 0xA0        | DATA1L_VOL<br>Data1 Left Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB  |
| 23:16          | R/W        | 0xA0        | DATA1R_VOL<br>Data1 Right Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |
| 15:8           | R/W        | 0xA0        | DATA0L_VOL<br>Data0 Left Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB  |

| Offset: 0x0030 |            |             | Register Name: DATA0_DATA1_VOL_CTR                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                   |
| 7:0            | R/W        | 0xA0        | <p>DATA0R_VOL<br/>Data0 Right Channel Volume Control<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>0x02: ...<br/>0x0F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>0xA2: ...<br/>0xFF: 71.25 dB</p> |

#### 8.2.5.13 0x0034 DATA2 and DATA3 Volume Control Register (Default Value: 0xA0A0\_A0A0)

| Offset: 0x0034 |            |             | Register Name: DATA2_DATA3_VOL_CTR                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                   |
| 31:24          | R/W        | 0xA0        | <p>DATA3L_VOL<br/>Data3 Light Channel Volume Control<br/>(-119.25 dB to 71.25 dB, 0.75 dB/Step)</p> <p>0x00: Mute<br/>0x01: -119.25 dB<br/>0x02: ...<br/>0x0F: -0.75 dB<br/>0xA0: 0 dB<br/>0xA1: 0.75 dB<br/>0xA2: ...<br/>0xFF: 71.25 dB</p> |

| Offset: 0x0034 |            |             | Register Name: DATA2_DATA3_VOL_CTR                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 23:16          | R/W        | 0xA0        | DATA3R_VOL<br>Data3 Right Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |
| 15:8           | R/W        | 0xA0        | DATA2L_VOL<br>Data2 Left Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB  |
| 7:0            | R/W        | 0xA0        | DATA2R_VOL<br>Data2 Right Channel Volume Control<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |

### 8.2.5.14 0x0038 High Pass Filter Enable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: HPF_EN_CTR                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:8           | /          | /           | /                                                                                            |
| 7              | R/W        | 0x0         | HPF_DATA3_CHR_EN<br>High Pass Filter DATA3 Right Channel Enable<br>0: Disabled<br>1: Enabled |
| 6              | R/W        | 0x0         | HPF_DATA3_CHL_EN<br>High Pass Filter DATA3 Left Channel Enable<br>0: Disabled<br>1: Enabled  |
| 5              | R/W        | 0x0         | HPF_DATA2_CHR_EN<br>High Pass Filter DATA2 Right Channel Enable<br>0: Disabled<br>1: Enabled |
| 4              | R/W        | 0x0         | HPF_DATA2_CHL_EN<br>High Pass Filter DATA2 Left Channel Enable<br>0: Disabled<br>1: Enabled  |
| 3              | R/W        | 0x0         | HPF_DATA1_CHR_EN<br>High Pass Filter DATA1 Right Channel Enable<br>0: Disabled<br>1: Enabled |
| 2              | R/W        | 0x0         | HPF_DATA1_CHL_EN<br>High Pass Filter DATA1 Left Channel Enable<br>0: Disabled<br>1: Enabled  |
| 1              | R/W        | 0x0         | HPF_DATA0_CHR_EN<br>High Pass Filter DATA0 Right Channel Enable<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | HPF_DATA0_CHL_EN<br>High Pass Filter DATA0 Left Channel Enable<br>0: Disabled<br>1: Enabled  |

#### 8.2.5.15 0x003C High Pass Filter Coefficient Register (Default Value: 0x0OFF\_AA45)

| Offset: 0x003C |            |             | Register Name: HPF_COEF_REG             |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:0           | R/W        | 0x0OFFAA45  | HPF_COE<br>High Pass Filter Coefficient |

#### 8.2.5.16 0x0040 High Pass Filter Gain Register (Default Value: 0x0OFF\_D522)

| Offset: 0x0040 |            |             | Register Name: HPF_GAIN_REG       |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:0           | R/W        | 0x0OFFD522  | HPF_GAIN<br>High Pass Filter Gain |

## 8.3 OWA

### 8.3.1 Overview

The One Wire Audio (OWA) provides a serial bus interface for audio data. This interface is widely used for consumer audio.

The OWA includes the following features:

- One OWA TX
- Compliance with S/PDIF interface
- IEC-60958 transmitter functionality
- Supports 16-bit, 20-bit, and 24-bit data formats
- One 128×24bits TXFIFO for audio data transfer
- Programmable FIFO thresholds
- Supports TX DMA slave interface
- Function clock includes 24.576 MHz and 22.579 MHz frequency
- Hardware parity generation on the transmitter
- Supports channel status insertion for the transmitter
- Supports interrupts and DMA

### 8.3.2 Block Diagram

The following figure shows the OWA block diagram.

**Figure 8-14 OWA Block Diagram**



OWA contains the following sub-blocks:

**Table 8-7 OWA Sub-blocks**

| Sub-block     | Description                                                           |
|---------------|-----------------------------------------------------------------------|
| Registers     | Analyze the configuration parameter, DMA requests, and IRQ feedbacks. |
| Transmitter   | Sends the data                                                        |
| FSM           | Finite state machine                                                  |
| Clock Divider | Clock divider circuit                                                 |

### 8.3.3 Functional Description

#### 8.3.3.1 External Signals

The OWA is a Biphase-Mark Encoding Digital Audio Transfer protocol. In this protocol, the CLK signal and data signal are transferred in the same line. The following figure describes the external signals of OWA. OWA-OUT is the output pin for the output CLK and DATA.

**Table 8-8 OWA External Signals**

| Signal Name | Description | Type |
|-------------|-------------|------|
| OWA-OUT     | OWA output  | O    |

### 8.3.3.2 Clock Sources

The following tables describe the clock sources for OWA. For clock setting, configurations and gating information, refer to section 3.3 “[CCU](#)”.

**Table 8-9 OWA Clock Sources**

| Clock Name       | Description                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------|
| PLL_AUDIO0(1X)   | By default, PLL_AUDIO0(1X) is 24.5714 MHz, and PLL_AUDIO0(4X) is 98.2856 MHz.                                        |
| PLL_AUDIO0(4X)   |                                                                                                                      |
| PLL_AUDIO1(DIV2) | By default, PLL_AUDIO1 is 3072 MHz, PLL_AUDIO1(DIV2) is 1536 MHz, and PLL_AUDIO1(DIV5) is 614.4 MHz (24.576 MHz*25). |
| PLL_AUDIO1(DIV5) |                                                                                                                      |

### 8.3.3.3 Biphase-Mark Code (BMC)

In the OWA format, the digital signal is coded using the biphase-mark code (BMC). The clock, frame, and data are embedded in only one signal—the data pin. In the BMC system, each data bit is encoded into two logical states (00, 01, 10, or 11) at the pin. The following figure and table show how data is encoded to the BMC format.

The frequency of the clock is twice the data bit rate, as shown in the following figure. Also, the clock is always programmed to  $128 \times fs$ , where  $fs$  is the sample rate. The device receiving in the OWA format can recover the clock and frame information from the BMC signal.

**Figure 8-15 OWA Biphase-Mark Code**



**Table 8-10 Biphase-Mark Encoder**

| Data | Previous State | BMC |
|------|----------------|-----|
| 0    | 0              | 11  |

| Data | Previous State | BMC |
|------|----------------|-----|
| 0    | 1              | 00  |
| 1    | 0              | 10  |
| 1    | 1              | 01  |

### 8.3.3.4 OWA Transmit Format

The OWA supports digital audio data transfer and receive. It also supports full-duplex synchronous work mode.

The software can set the work mode by the OWA Control Register.

Every audio sample transmitted in a sub-frame consists of 32-bit, numbered from 0 to 31. The following figure shows a sub-frame.

Figure 8-16 OWA Sub-Frame Format



**Bits 0-3** carry one of the four permitted preambles to signify the type of audio sample in the current sub-frame.

The preamble is not encoded in BMC format, and therefore the preamble code can contain more than two consecutive 0 or 1 logical states in a row.

**Bits 4-27** carry the audio sample word in linear 2s-complement representation. The most-significant bit (MSB) is carried by bit 27. When a 24-bit coding range is used, the least-significant bit (LSB) is in bit 4. When a 20-bit coding range is used, bit[8:27] carry the audio sample word with the LSB in bit 8. Bit[4:7] may be used for other applications and are designated auxiliary sample bits.

If the source provides fewer bits than the interface allows (either 20 or 24), the unused LSBs are set to logical 0. For a nonlinear PCM audio application or a data application, the main data field may carry any other information.

**Bit 28** carries the validity bit (V) associated with the main data field in the sub-frame.

**Bit 29** carries the user data channel (U) associated with the main data field in the sub-frame.

**Bit 30** carries the channel status information (C) associated with the main data field in the sub-frame. The channel status indicates if the data in the sub-frame is a digital audio or some other type of data.

**Bit 31** carries a parity bit (P) such that bit 4-31 carry an even number of 1s and an even number of 0s (even parity). As shown in the following table, the preambles (bit 0-3) are also defined with even parity.

Table 8-11 Preamble Codes

| Preamble Code | Previous Logical State | Logical State | Description                      |
|---------------|------------------------|---------------|----------------------------------|
| B (or Z)      | 0                      | 1110 1000     | Start of a block and sub-frame 1 |
| M (or X)      | 0                      | 1110 0010     | Sub-frame 1                      |
| W (or Y)      | 0                      | 1110 0100     | Sub-frame 2                      |

Figure 8-17 OWA Frame/Block Format



### 8.3.3.5 Audio Sample Ratio Detection

The sampling rate is calculated according to the data pulse back-stepping method. In the first phase lock of the CDR, find 1 Frame period, count by using the high-speed sampling clock, and read the counting value of the pulse, then the sampling rate can be calculated.

Table 8-12 The Corresponding Relation between Different System Clock and Sample Ratio

| Sample Clock Cycles  |                    |                 |
|----------------------|--------------------|-----------------|
| TX Sample Rate (kHz) | 196.608 MHz-SysClk | 200 MHz-SysClk  |
| 22.05                | 8916( $\pm 5$ )    | 9070( $\pm 5$ ) |
| 24                   | 8192( $\pm 5$ )    | 8333( $\pm 5$ ) |
| 32                   | 6144( $\pm 5$ )    | 6250( $\pm 5$ ) |
| 44.1                 | 4458( $\pm 5$ )    | 4535( $\pm 5$ ) |
| 48                   | 4096( $\pm 5$ )    | 4166( $\pm 5$ ) |
| 96                   | 2048( $\pm 5$ )    | 2083( $\pm 5$ ) |
| 176.4                | 1114( $\pm 5$ )    | 1133( $\pm 5$ ) |
| 192                  | 1024( $\pm 5$ )    | 1041( $\pm 5$ ) |

### 8.3.3.6 Operation Modes

The software operation of the OWA is divided into five steps: system setup, OWA initialization, channel setup, DMA setup and enable/disable module. The following sections describe these five steps.

**Figure 8-18 OWA Operation Flow**



#### 1. System Setup and OWA Initialization

The first step in the OWA initialization is properly programming the GPIO because the OWA port is a multiplex pin. You can find the function in section 9.7 “”.

The clock source for the OWA should be followed. Firstly, reset the audio PLL in [PLL\\_AUDIOx Control Register](#). Secondly, set up the frequency of the Audio PLL in the [PLL\\_AUDIOx Control Register](#). After that, enable the OWA gating. Lastly, enable the OWA bus gating.

After the system setup, the register of OWA can be set up. Firstly, reset the OWA by writing 1 to [OWA\\_CTL\[0\]](#) and clear the TX FIFO by writing 1 to [OWA\\_FCTL\[17:16\]](#). After that, enable the globe enable bit by writing 1 to [OWA\\_CTL\[1\]](#) and clear the interrupt and TX counter by setting [OWAISTA](#) and [OWATX\\_CNT](#).

#### 2. Channel Setup and DMA Setup

You can set up the audio type, clock divider ratio, the sample format, and the trigger level, and so on. The setup of the register can be found in the specification.

The OWA supports two methods to transfer the data. The most common way is DMA, the configuration of DMA can be found in section 3.9 “[DMAC](#)”. In this module, you just enable the DRQ in [OWA\\_INT\[7\]](#).

#### 3. Enable and Disable OWA

To enable the function, you can enable TX by writing [OWA\\_TX\\_CFIG\[31\]](#). After that, enable OWA by writing 1 to [OWA\\_CTL\[1\]](#). Writing 0 to [OWA\\_CTL\[1\]](#) to disable process.

### 8.3.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| OWA         | 0x02036000   |

| Register Name | Offset | Description                     |
|---------------|--------|---------------------------------|
| OWA_GEN_CTL   | 0x0000 | OWA General Control Register    |
| OWA_TX_CFIG   | 0x0004 | OWA TX Configuration Register   |
| OWAISTA       | 0x000C | OWA Interrupt Status Register   |
| OWAFCTL       | 0x0014 | OWA FIFO Control Register       |
| OWAFSTA       | 0x0018 | OWA FIFO Status Register        |
| OWAINT        | 0x001C | OWA Interrupt Control Register  |
| OWATXFIFO     | 0x0020 | OWA TX FIFO Register            |
| OWATX_CNT     | 0x0024 | OWA TX Counter Register         |
| OWATX_CHSTA0  | 0x002C | OWA TX Channel Status Register0 |
| OWATX_CHSTA1  | 0x0030 | OWA TX Channel Status Register1 |

### 8.3.5 Register Description

#### 8.3.5.1 0x0000 OWA General Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0000 |            |             | Register Name: OWA_CTL                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                  |
| 7              | R          | 0x1         | Reserved                                                                                                                                                                           |
| 6:2            | /          | /           | /                                                                                                                                                                                  |
| 1              | R/W        | 0x0         | <p>GEN<br/>Global Enable<br/>Disabling this bit overrides the operations of enabling and flushing all FIFOs by any other blocks or channels.</p> <p>0: Disabled<br/>1: Enabled</p> |

| Offset: 0x0000 |            |             | Register Name: OWA_CTL                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                |
| 0              | R/W        | 0x0         | <p>RST_TX<br/>Reset TX<br/>0: Normal<br/>1: Reset<br/>Self clear to 0.</p> |

### 8.3.5.2 0x0004 OWA TX Configure Register (Default Value: 0x0000\_00F0)

| Offset: 0x0004 |            |             | Register Name: OWA_TX_CFIG                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31             | R/W        | 0x0         | <p>TX_SINGLE_MODE<br/>Tx Single Channel Mode<br/>0: Disabled<br/>1: Enabled</p>                                                                              |
| 30:18          | /          | /           | /                                                                                                                                                            |
| 17             | R/W        | 0x0         | <p>ASS<br/>Audio Sample Select when TX FIFO Underrun<br/>0: Sending 0<br/>1: Sending the last audio<br/><b>Note: This bit is only valid in PCM mode.</b></p> |
| 16             | R/W        | 0x0         | <p>TX_AUDIO<br/>TX Data Type<br/>0: Linear PCM (Valid bit of both sub-frame set to 0 )<br/>1: Non-audio (Valid bit of both sub-frame set to 1)</p>           |
| 15:9           | /          | /           | /                                                                                                                                                            |
| 8:4            | R/W        | 0xF         | <p>TX_RATIO<br/>TX Clock Divide Ratio<br/>Clock divide ratio = TX_TATIO + 1<br/><math>F_s = PLL\_AUDIO / [(TX\_TATIO + 1) * 64 * 2]</math></p>               |
| 3:2            | R/W        | 0x0         | <p>TX_SF<br/>TX Sample Format<br/>00: 16 bits<br/>01: 20 bits<br/>10: 24 bits<br/>11: Reserved</p>                                                           |

| Offset: 0x0004 |            |             | Register Name: OWA_TX_CFIG                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 1              | R/W        | 0x0         | TX_CHM<br>CHSTMODE<br>0: Channel status A and B set to 0<br>1: Channel status A and B generated from TX_CHSTA |
| 0              | R/W        | 0x0         | TXEN<br>TX Enable<br>0: Disabled<br>1: Enabled                                                                |

### 8.3.5.3 0x000C OWA Interrupt Status Register (Default Value: 0x0000\_0010)

| Offset: 0x000C |            |             | Register Name: OWAISTA                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:7           | /          | /           | /                                                                                                                                                                                                  |
| 6              | R/W1C      | 0x0         | TXU_INT<br>TX FIFO Underrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Underrun Pending Interrupt<br>Writing "1" to clear this interrupt.                                                   |
| 5              | R/W1C      | 0x0         | TXO_INT<br>TX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Overrun Pending Interrupt<br>Writing "1" to clear this interrupt.                                                     |
| 4              | R/W1C      | 0x1         | TXE_INT<br>TX FIFO Empty Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Empty Pending Interrupt<br>Writing "1" to clear this interrupt or automatically clear if the interrupt condition fails. |
| 3:0            | /          | /           | /                                                                                                                                                                                                  |

### 8.3.5.4 0x0014 OWA FIFO Control Register (Default Value: 0x0004\_0200)

| Offset: 0x0014 |            |             | Register Name: OWA_FCTL                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                             |
| 31             | R/W        | 0x0         | HUB_EN<br>Audio Hub Enable<br>The bit takes effect only when the TXEN is set to 1.<br>Audio codec/I2S1/I2S2/OWA TXFIFO Hub Enable.<br>0: Disabled<br>1: Enabled                                                                                                                         |
| 30             | R/W1C      | 0x0         | FTX<br>Write '1' to flush TXFIFO, self clear to '0'.                                                                                                                                                                                                                                    |
| 29:20          | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 19:12          | R/W        | 0x40        | TXTL<br>TX FIFO Empty Trigger Level<br>Interrupt and DMA request trigger level for TX FIFO normal condition.<br>Trigger Level = TXTL                                                                                                                                                    |
| 11:3           | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 2              | R/W        | 0x0         | TXIM<br>TXFIFO Input Mode (Mode0, 1)<br>0: Valid data at the MSB of TXFIFO Register<br>1: Valid data at the LSB of TXFIFO Register<br>Example for 20-bit transmitted audio sample:<br>Mode 0: TXFIFO[23:0] = {APB_WDATA[31:12], 4'h0}<br>Mode 1: TXFIFO[23:0] = {APB_WDATA[19:0], 4'h0} |
| 1:0            | /          | /           | /                                                                                                                                                                                                                                                                                       |

### 8.3.5.5 0x0018 OWA FIFO Status Register (Default Value: 0x8080\_0000)

| Offset: 0x0018 |            |             | Register Name: OWA_FSTA                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31             | R          | 0x1         | TXE<br>TXFIFO Empty (indicate the TXFIFO is not full)<br>0: No room for new sample in TXFIFO<br>1: More than one room for new sample in TXFIFO (>= 1 Word) |
| 30:24          | /          | /           | /                                                                                                                                                          |

| Offset: 0x0018 |            |             | Register Name: OWA_FSTA                    |
|----------------|------------|-------------|--------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                |
| 23:16          | R          | 0x80        | TXE_CNT<br>TXFIFO Empty Space Word Counter |
| 15:0           | /          | /           | /                                          |

### 8.3.5.6 0x001C OWA Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: OWA_INT                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:8           | /          | /           | /                                                                        |
| 7              | R/W        | 0x0         | TX_DRQ<br>TXFIFO Empty DRQ Enable<br>0: Disabled<br>1: Enabled           |
| 6              | R/W        | 0x0         | TXUI_EN<br>TXFIFO Underrun Interrupt Enable<br>0: Disabled<br>1: Enabled |
| 5              | R/W        | 0x0         | TXOI_EN<br>TXFIFO Overrun Interrupt Enable<br>0: Disabled<br>1: Enabled  |
| 4              | R/W        | 0x0         | TXEI_EN<br>TXFIFO Empty Interrupt Enable<br>0: Disabled<br>1: Enabled    |
| 3:0            | /          | /           | /                                                                        |

### 8.3.5.7 0x0020 OWA TX FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: OWA_TXFIFO                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:0           | W          | 0x0         | TX_DATA<br>Transmitting A, B channel data should be written this register one by one. A channel data is first, and then the B channel data. |

### 8.3.5.8 0x0024 OWA TX Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: OWA_TX_CNT                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | <p>TX_CNT<br/>TX Sample Counter<br/>The audio sample number of sending into TXFIFO.<br/>When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX sample counter register can be set to any initial value at any time. After updated by the initial value, the counter register should count on the base of this initial value.</p> |

### 8.3.5.9 0x002C OWA TX Channel Status Register0 (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: OWA_TX_CHSTA0                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31: 30         | /          | /           | /                                                                                                |
| 29:28          | R/W        | 0x0         | <p>CA<br/>Clock Accuracy<br/>00: Level 2<br/>01: Level 1<br/>10: Level 3<br/>11: Not matched</p> |

| Offset: 0x002C |            |             | Register Name: OWA_TX_CHSTA0                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                             |
| 27:24          | R/W        | 0x0         | FREQ<br>Sampling Frequency<br>0000: 44.1 kHz<br>0001: Not indicated<br>0010: 48 kHz<br>0011: 32 kHz<br>0100: 22.05 kHz<br>0101: Reserved<br>0110: 24 kHz<br>0111: Reserved<br>1000: Reserved<br>1001: 768 kHz<br>1010: 96 kHz<br>1011: Reserved<br>1100: 176.4 kHz<br>1101: Reserved<br>1110: 192 kHz<br>1111: Reserved |
| 23:20          | R/W        | 0x0         | CN<br>Channel Number                                                                                                                                                                                                                                                                                                    |
| 19:16          | R/W        | 0x0         | SN<br>Source Number                                                                                                                                                                                                                                                                                                     |
| 15:8           | R/W        | 0x0         | CC<br>Category Code<br>Indicates the kind of equipment that generates the digital audio interface signal.                                                                                                                                                                                                               |
| 7:6            | R/W        | 0x0         | MODE<br>Mode<br>00: Default Mode<br>01 to 11: Reserved                                                                                                                                                                                                                                                                  |

| Offset: 0x002C |            |             | Register Name: OWA_TX_CHSTA0                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5:3            | R/W        | 0x0         | <p>EMP<br/>Emphasis<br/>Additional format information<br/>For bit 1 = “0”, Linear PCM audio mode:<br/>000: 2 audio channels without pre-emphasis<br/>001: 2 audio channels with 50 µs/15 µs pre-emphasis<br/>010: Reserved (for 2 audio channels with pre-emphasis)<br/>011: Reserved (for 2 audio channels with pre-emphasis)<br/>100 to 111: Reserved<br/>For bit 1 = “1”, other than Linear PCM applications:<br/>000: Default state<br/>001 to 111: Reserved</p> |
| 2              | R/W        | 0x0         | <p>CP<br/>Copyright<br/>0: Copyright is asserted<br/>1: No copyright is asserted</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 1              | R/W        | 0x0         | <p>TYPE<br/>Audio Data Type<br/>0: Linear PCM samples<br/>1: Non-linear PCM audio</p>                                                                                                                                                                                                                                                                                                                                                                                |
| 0              | R/W        | 0x0         | <p>PRO<br/>Application Type<br/>0: Consumer application<br/>1: Professional application<br/>This bit must be fixed to “0”.</p>                                                                                                                                                                                                                                                                                                                                       |

### 8.3.5.10 0x0030 OWA TX Channel Status Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: OWA_TX_CHSTA1                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31:10          | /          | /           | /                                                                                                                                                                         |
| 9:8            | R/W        | 0x0         | <p>CGMS_A<br/>00: Copying is permitted without restriction<br/>01: One generation of copies may be made<br/>10: Condition not be used<br/>11: No copying is permitted</p> |

| Offset: 0x0030 |            |             | Register Name: OWA_TX_CHSTA1                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:4            | R/W        | 0x0         | <p>ORIG_FREQ<br/>Original Sampling Frequency</p> <p>0000: Not indicated</p> <p>0001: 192 kHz</p> <p>0010: 12 kHz</p> <p>0011: 176.4 kHz</p> <p>0100: Reserved</p> <p>0101: 96 kHz</p> <p>0110: 8 kHz</p> <p>0111: 88.2 kHz</p> <p>1000: 16 kHz</p> <p>1001: 24 kHz</p> <p>1010: 11.025 kHz</p> <p>1011: 22.05 kHz</p> <p>1100: 32 kHz</p> <p>1101: 48 kHz</p> <p>1110: Reserved</p> <p>1111: 44.1 kHz</p> |
| 3:1            | R/W        | 0x0         | <p>WL<br/>Sample Word Length</p> <p>For bit 0 = "0":</p> <p>000: Not indicated</p> <p>001: 16 bits</p> <p>010: 18 bits</p> <p>100: 19 bits</p> <p>101: 20 bits</p> <p>110: 17 bits</p> <p>111: Reserved</p> <p>For bit 0 = "1":</p> <p>000: Not indicated</p> <p>001: 20 bits</p> <p>010: 22 bits</p> <p>100: 23 bits</p> <p>101: 24 bits</p> <p>110: 21 bits</p> <p>111: Reserved</p>                    |

| Offset: 0x0030 |            |             | Register Name: OWA_TX_CHSTA1                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 0              | R/W        | 0x0         | MWL<br>Max Word Length<br>0: Maximum audio sample word length is 20 bits<br>1: Maximum audio sample word length is 24 bits |

## 8.4 Audio Codec

### 8.4.1 Overview

The Audio Codec is high-performance audio encoder and decoder module which supports DAC/ADC, dynamic range controller (DRC) and dynamic voltage controller (DVC) functions.

The Audio Codec has the following features:

- Two audio digital-to-analog converter (DAC) channels
  - Supports the DAC sample rate from 8 kHz to 192 kHz
  - $100 \pm 2$  dB SNR@A-weight,  $-85 \pm 3$  dB THD + N
  - Supports 16-bit and 20-bit audio sample resolution
- One audio output
  - One stereo headphone output: HPOUTL/R
- Three audio analog-to-digital converter (ADC) channels
  - Supports the ADC sample rate from 8 kHz to 48 kHz
  - $95 \pm 3$  dB SNR@A-weight,  $-80 \pm 3$  dB THD + N
  - Supports 16-bit and 20-bit audio sample resolution
- Three audio inputs
  - One differential microphone input: MICIN3P/3N, or one single-end microphone input: MICIN3P
  - One stereo LINEIN input: LINEINL/R
  - One stereo FMIN input: FMINL/R
- Stereo headphone driver
  - $95 \pm 3$  dB SNR@A-weight
  - Output Level 0.55 Vrms@ $10 \text{ k}\Omega$ /THD+N -77±3dB, 0.37Vrms@ $16 \Omega$ /THD+N -40dB
- Supports Dynamic Range Controller (DRC) adjusting the ADC recording and DAC playback
- One 128x20-bit FIFO for DAC data transmit, one 128x20-bit FIFO for ADC data receive
- Programmable FIFO thresholds
- Supports interrupts and DMA
- Internal HPLDO output for HPVCC

- Internal ALDO output for AVCC

### 8.4.2 Block Diagram

The following figure shows the block diagram of Audio Codec.

**Figure 8-19 Audio Codec Block Diagram**



### 8.4.3 Functional Description

#### 8.4.3.1 External Signals

**Table 8-13 Audio Codec External Signals**

| Signal  | Type | Description                          |
|---------|------|--------------------------------------|
| MICIN3P | AI   | Positive Differential Input for MIC3 |
| MICIN3N | AI   | Negative Differential Input for MIC3 |
| FMINL   | AI   | FMIN Left Input                      |
| FMINR   | AI   | FMIN Right Input                     |
| LINEINL | AI   | LINEIN Left Single-End Input         |
| LINEINR | AI   | LINEIN Right Single-End Input        |

| Signal  | Type | Description                                    |
|---------|------|------------------------------------------------|
| HPOUTL  | AO   | Headphone Light Output                         |
| HPOUTR  | AO   | Headphone Right Output                         |
| HPOUTFB | AI   | Pseudo Differential Headphone Ground Reference |
| VRA1    | AO   | Internal Reference Voltage                     |
| VRA2    | AO   | Internal Reference Voltage                     |
| HPVCC   | P    | Headphone Power                                |
| AVCC    | P    | Analog Power                                   |
| AGND    | G    | Analog Ground                                  |

#### 8.4.3.2 Clock Sources

The following figure describes the clock source of Audio Codec. For clock setting, configuration, and gating information, refer to section 3.3 “[CCU](#)”.

**Figure 8-20 Audio Codec Clock Diagram**



The clock source for the digital part is the PLL\_AUDIO0 and PLL\_AUDIO1. For the ADC clock, configure [AUDIO\\_CODEC\\_ADC\\_CLK\\_REG\[25:24\]](#) to select the clock source. For the DAC clock, configure

AUDIO\_CODEC\_DAC\_CLK\_REG[25:24] to select the clock source. The PK-PK jitter of PLL\_AUDIO0 and PLL\_AUDIO1 should be less than 200 ps.

The clock source for the analog part is the CK\_ADC and CK\_DAC, both of which are divided from the digital part.

#### 8.4.3.3 Reset System

##### Digital Part Reset System

The following figure shows the reset system of the audio codec digital part.

**Figure 8-21 Audio Codec Digital Part Reset System**



The SYS\_RST comes from the VDD-SYS domain and is produced by the RTC domain. Each domain has the debounce to confirm the reset system is strong. For the codec register part, MIX can be reset by the SYS\_RST when being powered on or the system soft is writing the reset control logic. The other parts can be reset by the soft configuration through writing the register.

##### Analog Part Reset System

The following figure shows the reset system of the audio codec analog part.

**Figure 8-22 Audio Codec Analog Part Reset System**



When AVCC is powered on, it sends the AVCC\_POR signal. The AVCC\_POR signal passes the level shift and RC filter part to the ADDA logic core.

#### 8.4.3.4 Data Path Diagram

The following figure shows a data path of the Audio Codec.

**Figure 8-23 Audio Codec Data Path Diagram**



#### 8.4.3.5 Three ADCs

The three ADCs are used for recording stereo sound and a reference signal. The sample rates of the three ADCs are independent of the DAC sample rate. The digital ADC part can be enabled or disabled by the bit[28] of the [AC\\_ADC\\_FIFOC](#) register.

#### 8.4.3.6 Stereo DAC

The stereo DAC sample rate can be configured by setting the register. To save power, the analog DACL can be enabled or disabled by setting the bit[15] of the [DAC\\_REG](#) register, and the analog DACR can be enabled or disabled by setting the bit[14] of the [DAC\\_REG](#) register. The digital DAC part can be enabled or disabled by the bit[31] of the [AC\\_DAC\\_DPC](#) register.

#### 8.4.3.7 Analog Audio Input Path

The Audio Codec supports 3 analog audio input paths:

- MICIN3P/N
- LINEINL/R
- FMINL/R

LINEINL, FMINL provide differential input that can be mixed into the ADC1 record mixer. LINEINR, FMINR provide differential input that can be mixed into the ADC2 record mixer. MICIN3P/N provides differential input. The MICIN is a high impedance, low capacitance input suitable for connecting to various differential microphones of different dynamics and sensitivity. The gain for each pre-amplifier can be set independently.

#### 8.4.3.8 Analog Audio Output Path

The Audio Codec has 1 analog output paths:

- HPOUTL/R

The headphone PA is powered up or down by HP\_REG[bit15] (HPPA\_EN). HPOUTL/R can drive a 16R or 32R headphone load without DC capacitors by using Charge Pump to generate the negative rails. HP-FB is the ground loop noise rejection feedback.

Figure 8-24 Headphone Output Application



#### 8.4.3.9 Interrupts

The Audio Codec has two interrupts. The following figure describes the Audio Codec interrupt system.

**Figure 8-25 Audio Codec Interrupt System**

#### 8.4.3.10 Digital Audio Processor (DAP)

The DAP module is used to remove the DC offset and automatically adjusts the volume to a flatten volume level. It mainly consists of two HPF and one DRC.

The following figure shows the DAP data flow.

**Figure 8-26 DAP Data Flow**

#### HPF Function

The DAP has individual channel high pass filter (HPF, -3 dB cutoff < 1 Hz) that can be enabled and disabled. The filter cutoff frequency is less than 1 Hz that can be removed DC offset from ADC recording. The HPF can also be bypassed.

**Figure 8-27 HPF Logic Structure****DRC Function**

The DRC scheme has three thresholds, three offsets, and four slopes (all programmable). There is one ganged DRC for the left and right channels. The following figure shows the diagram of DRC input/output.

**Figure 8-28 DRC Block Diagram****Figure 8-29 DRC Static Curve Parameters**

Professional-quality dynamic range compression automatically adjusts the volume to flatten volume level.

One DRC for left/right and one DRC for the subwoofer.

Each DRC has an adjustable threshold, offset, and compression levels, programmable energy, attack, and decay time constants.

**Transparent compression:** Compressors can attack fast enough to avoid apparent clipping before engaging, and decay times can be set slow enough to avoid pumping.

Configure the DRC parameters according to the following guidelines:

- **Number format**

The Number format is N.M which means there are N bits to the left of the decimal point including the sign bit and M bits to the right of the decimal point. For example, Numbers formatted 9.23 means that there are 9 bits at the left of the decimal point and 23 bits at the right decimal point.

- **Energy Filter**

The following figure shows the structure of the energy filter.

**Figure 8-30 Energy Filter Structure**



The Energy Filter is to estimate the RMS value of the audio data stream into DRC and has two parameters, which determine the time window over which RMS to be made. The parameter is computed by

$$\alpha = 1 - e^{-2.2T_S/ta}$$

For the Compression Control, there are ten parameters (ET, CT, LT, Ke, Kn, Kc, Kl, OPL, OPC, and OPE), which are all programmable, and the computation will be explained as follows.

- **Threshold Parameter Computation (T parameter)**

The threshold is the value that determines the signal to be compressed or not. When the RMS of the signal is larger than the threshold, the signal will be compressed. The value of threshold input to the coefficient

register is computed by  $T_{in} = -\frac{T_{dB}}{6.0206}$ .

Where,  $T_{dB}$  must less than zero, the positive value is illegal.

For example, it is desired to set CT = -40 dB, then the Tin require to set CT to -40 dB is  $CT_{in} = -(-40 \text{ dB})/6.0206 = 6.644$ , CT<sub>in</sub> is entered as a 32-bit number in 8.24 format.

Therefore,  $CT_{in} = 6.644 = 0000\ 0110.1010\ 0100\ 1101\ 0011\ 1100\ 0000 = 0x06A4\ D3C0$  in 8.24 format.

- **Slope Parameter Computation (K parameter)**

The K is the slope within the compression region. For example, an n:1 compression means that an output increase of 1 dB is for n dB RMS input. The k input to the coefficient ram is computed by  $K = \frac{1}{n}$

Where, n is from 1 to 50, and must be an integer.

For example, it is desired to set to 2:1, then the Kc requires to set to 2:1, is  $K_c = 1/2 = 0.5$ , Kc is entered as a 32-bit number in 8.24 format.

Therefore,  $K_c = 0.5 = 0000\ 0000.1000\ 0000\ 0000\ 0000.0000 = 0x0080\ 0000$  in 8.24 format.

- **Gain Smooth Filter**

The Gain Smooth Filter is to smooth the gain and control the ratio of gain increase and decrease. The decay time and attack are shown in Figure 8-36. The structure of the Gain Smooth filter is also the Alpha filter, so the rise time computation is the same as the Energy filter which is  $\alpha = 1 - e^{-2.2T_{sfa}}$ .

**Figure 8-31 Gain Smooth Filter**



#### 8.4.4 Programming Guidelines

##### 8.4.4.1 Record Process

In recording mode, the analog audio signals are recorded from the microphones at the specified sample rate, processed by the ADC, and then transferred to the DRAM via the DMA.

- Step 1** Codec initialization: configure **AUDIO\_CODEC\_BGR\_REG** to open the audio codec bus clock gating and de-assert bus reset; configure **AUDIO\_CODEC\_ADC\_CLK\_REG** and **PLL\_AUDIO0\_CTRL\_REG** to configure PLL\_Audio0 frequency and enable PLL\_Audio0. For details, refer to section 3.3 “[CCU](#)”.
- Step 2** Configure the sample rate and data transfer format, then open the ADC.
- Step 3** Configure the DMA and DMA request.
- Step 4** Enable the ADC DRQ and DMA.

#### 8.4.4.2 Playback Process

In playback mode, the audio data are transferred from the DRAM via DMA, processed by the DAC, and finally output via the analog interface.

- Step 1** Codec initialization: configure **AUDIO\_CODEC\_BGR\_REG** to open the audio codec bus clock gating and de-assert bus reset; configure **AUDIO\_CODEC\_DAC\_CLK\_REG** and **PLL\_AUDIO1\_CTRL\_REG** to configure PLL\_Audio1 frequency and enable PLL\_Audio1. For details, refer to section 3.3 “[CCU](#)”.
- Step 2** Configure the sample rate and data transfer format, then open the DAC.
- Step 3** Configure the DMA and DMA request.
- Step 4** Enable the DAC DRQ and DMA.

#### 8.4.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| Audio Codec | 0x02030000   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| AC_DAC_DPC    | 0x0000 | DAC Digital Part Control Register |
| DAC_VOL_CTRL  | 0x0004 | DAC Volume Control Register       |
| AC_DAC_FIFOC  | 0x0010 | DAC FIFO Control Register         |
| AC_DAC_FIFOS  | 0x0014 | DAC FIFO Status Register          |
| AC_DAC_TXDATA | 0x0020 | DAC TX DATA Register              |
| AC_DAC_CNT    | 0x0024 | DAC TX/FIFO Counter Register      |
| AC_DAC_DG     | 0x0028 | DAC Debug Register                |
| AC_ADC_FIFOC  | 0x0030 | ADC FIFO Control Register         |
| ADC_VOL_CTRL1 | 0x0034 | ADC Volume Control1 Register      |

| Register Name         | Offset | Description                                                     |
|-----------------------|--------|-----------------------------------------------------------------|
| AC_ADC_FIFOS          | 0x0038 | ADC FIFO Status Register                                        |
| AC_ADC_RXDATA         | 0x0040 | ADC RX Data Register                                            |
| AC_ADC_CNT            | 0x0044 | ADC RX Counter Register                                         |
| AC_ADC_DG             | 0x004C | ADC Debug Register                                              |
| ADC_DIG_CTRL          | 0x0050 | ADC Digital Control Register                                    |
| VRA1SPEEDUP_DOWN_CTRL | 0x0054 | VRA1 Speedup Down Control Register                              |
| AC_DAC_DAP_CTRL       | 0x00F0 | DAC DAP Control Register                                        |
| AC_ADC_DAP_CTR        | 0x00F8 | ADC DAP Control Register                                        |
| AC_DAC_DRC_HHPFC      | 0x0100 | DAC DRC High HPF Coef Register                                  |
| AC_DAC_DRC_LHPFC      | 0x0104 | DAC DRC Low HPF Coef Register                                   |
| AC_DAC_DRC_CTRL       | 0x0108 | DAC DRC Control Register                                        |
| AC_DAC_DRC_LPFBAT     | 0x010C | DAC DRC Left Peak Filter High Attack Time Coef Register         |
| AC_DAC_DRC_LPFLAT     | 0x0110 | DAC DRC Left Peak Filter Low Attack Time Coef Register          |
| AC_DAC_DRC_RPFHAT     | 0x0114 | DAC DRC Right Peak Filter High Attack Time Coef Register        |
| AC_DAC_DRC_RPFLAT     | 0x0118 | DAC DRC Peak Filter Low Attack Time Coef Register               |
| AC_DAC_DRC_LPFBRT     | 0x011C | DAC DRC Left Peak Filter High Release Time Coef Register        |
| AC_DAC_DRC_LPFLRT     | 0x0120 | DAC DRC Left Peak Filter Low Release Time Coef Register         |
| AC_DAC_DRC_RPFHRT     | 0x0124 | DAC DRC Right Peak filter High Release Time Coef Register       |
| AC_DAC_DRC_RPFLRT     | 0x0128 | DAC DRC Right Peak filter Low Release Time Coef Register        |
| AC_DAC_DRC_LRMSBAT    | 0x012C | DAC DRC Left RMS Filter High Coef Register                      |
| AC_DAC_DRC_LRMSLAT    | 0x0130 | DAC DRC Left RMS Filter Low Coef Register                       |
| AC_DAC_DRC_RRMSBAT    | 0x0134 | DAC DRC Right RMS Filter High Coef Register                     |
| AC_DAC_DRC_RRMSLAT    | 0x0138 | DAC DRC Right RMS Filter Low Coef Register                      |
| AC_DAC_DRC_HCT        | 0x013C | DAC DRC Compressor Threshold High Setting Register              |
| AC_DAC_DRC_LCT        | 0x0140 | DAC DRC Compressor Slope High Setting Register                  |
| AC_DAC_DRC_HKC        | 0x0144 | DAC DRC Compressor Slope High Setting Register                  |
| AC_DAC_DRC_LKC        | 0x0148 | DAC DRC Compressor Slope Low Setting Register                   |
| AC_DAC_DRC_HOPC       | 0x014C | DAC DRC Compressor High Output at Compressor Threshold Register |

| Register Name       | Offset | Description                                                    |
|---------------------|--------|----------------------------------------------------------------|
| AC_DAC_DRC_LOPC     | 0x0150 | DAC DRC Compressor Low Output at Compressor Threshold Register |
| AC_DAC_DRC_HLT      | 0x0154 | DAC DRC Limiter Threshold High Setting Register                |
| AC_DAC_DRC_LLT      | 0x0158 | DAC DRC Limiter Threshold Low Setting Register                 |
| AC_DAC_DRC_HKI      | 0x015C | DAC DRC Limiter Slope High Setting Register                    |
| AC_DAC_DRC_LKI      | 0x0160 | DAC DRC Limiter Slope Low Setting Register                     |
| AC_DAC_DRC_HOPL     | 0x0164 | DAC DRC Limiter High Output at Limiter Threshold               |
| AC_DAC_DRC_LOPL     | 0x0168 | DAC DRC Limiter Low Output at Limiter Threshold                |
| AC_DAC_DRC_HET      | 0x016C | DAC DRC Expander Threshold High Setting Register               |
| AC_DAC_DRC_LET      | 0x0170 | DAC DRC Expander Threshold Low Setting Register                |
| AC_DAC_DRC_HKE      | 0x0174 | DAC DRC Expander Slope High Setting Register                   |
| AC_DAC_DRC_LKE      | 0x0178 | DAC DRC Expander Slope Low Setting Register                    |
| AC_DAC_DRC_HOPE     | 0x017C | DAC DRC Expander High Output at Expander Threshold             |
| AC_DAC_DRC_LOPE     | 0x0180 | DAC DRC Expander Low Output at Expander Threshold              |
| AC_DAC_DRC_HKN      | 0x0184 | DAC DRC Linear Slope High Setting Register                     |
| AC_DAC_DRC_LKN      | 0x0188 | DAC DRC Linear Slope Low Setting Register                      |
| AC_DAC_DRC_SFHAT    | 0x018C | DAC DRC Smooth filter Gain High Attack Time Coef Register      |
| AC_DAC_DRC_SFLAT    | 0x0190 | DAC DRC Smooth filter Gain Low Attack Time Coef Register       |
| AC_DAC_DRC_SFVRT    | 0x0194 | DAC DRC Smooth filter Gain High Release Time Coef Register     |
| AC_DAC_DRC_SFLRT    | 0x0198 | DAC DRC Smooth filter Gain Low Release Time Coef Register      |
| AC_DAC_DRC_MXGHS    | 0x019C | DAC DRC MAX Gain High Setting Register                         |
| AC_DAC_DRC_MXGLS    | 0x01A0 | DAC DRC MAX Gain Low Setting Register                          |
| AC_DAC_DRC_MNGHS    | 0x01A4 | DAC DRC MIN Gain High Setting Register                         |
| AC_DAC_DRC_MNGLS    | 0x01A8 | DAC DRC MIN Gain Low Setting Register                          |
| AC_DAC_DRC_EPSHC    | 0x01AC | DAC DRC Expander Smooth Time High Coef Register                |
| AC_DAC_DRC_EPSLC    | 0x01B0 | DAC DRC Expander Smooth Time Low Coef Register                 |
| AC_DAC_DRC_HPFHGAIN | 0x01B8 | DAC DRC HPF Gain High Coef Register                            |
| AC_DAC_DRC_HPFLGAIN | 0x01BC | DAC DRC HPF Gain Low Coef Register                             |
| AC_ADC_DRC_HHPFC    | 0x0200 | ADC DRC High HPF Coef Register                                 |
| AC_ADC_DRC_LHPFC    | 0x0204 | ADC DRC Low HPF Coef Register                                  |
| AC_ADC_DRC_CTRL     | 0x0208 | ADC DRC Control Register                                       |

| Register Name       | Offset | Description                                                     |
|---------------------|--------|-----------------------------------------------------------------|
| AC_ADC_DRC_LPFHAT   | 0x020C | ADC DRC Left Peak Filter High Attack Time Coef Register         |
| AC_ADC_DRC_LPFLAT   | 0x0210 | ADC DRC Left Peak Filter Low Attack Time Coef Register          |
| AC_ADC_DRC_RPFHAT   | 0x0214 | ADC DRC Right Peak Filter High Attack Time Coef Register        |
| AC_ADC_DRC_RPFLAT   | 0x0218 | ADC DRC Right Peak Filter Low Attack Time Coef Register         |
| AC_ADC_DRC_LPFHRT   | 0x021C | ADC DRC Left Peak Filter High Release Time Coef Register        |
| AC_ADC_DRC_LPFLRT   | 0x0220 | ADC DRC Left Peak Filter Low Release Time Coef Register         |
| AC_ADC_DRC_RPFHRT   | 0x0224 | ADC DRC Right Peak Filter High Release Time Coef Register       |
| AC_ADC_DRC_RPFLRT   | 0x0228 | ADC DRC Right Peak Filter Low Release Time Coef Register        |
| AC_ADC_DRC_LRMSSHAT | 0x022C | ADC DRC Left RMS Filter High Coef Register                      |
| AC_ADC_DRC_LRMSLAT  | 0x0230 | ADC DRC Left RMS Filter Low Coef Register                       |
| AC_ADC_DRC_RRMSSHAT | 0x0234 | ADC DRC Right RMS Filter High Coef Register                     |
| AC_ADC_DRC_RRMSLAT  | 0x0238 | ADC DRC Right RMS Filter Low Coef Register                      |
| AC_ADC_DRC_HCT      | 0x023C | ADC DRC Compressor Threshold High Setting Register              |
| AC_ADC_DRC_LCT      | 0x0240 | ADC DRC Compressor Slope High Setting Register                  |
| AC_ADC_DRC_HKC      | 0x0244 | ADC DRC Compressor Slope High Setting Register                  |
| AC_ADC_DRC_LKC      | 0x0248 | ADC DRC Compressor Slope Low Setting Register                   |
| AC_ADC_DRC_HOPC     | 0x024C | ADC DRC Compressor High Output at Compressor Threshold Register |
| AC_ADC_DRC_LOPC     | 0x0250 | ADC DRC Compressor Low Output at Compressor Threshold Register  |
| AC_ADC_DRC_HLT      | 0x0254 | ADC DRC Limiter Threshold High Setting Register                 |
| AC_ADC_DRC_LLTT     | 0x0258 | ADC DRC Limiter Threshold Low Setting Register                  |
| AC_ADC_DRC_HKI      | 0x025C | ADC DRC Limiter Slope High Setting Register                     |
| AC_ADC_DRC_LKI      | 0x0260 | ADC DRC Limiter Slope Low Setting Register                      |
| AC_ADC_DRC_HOPL     | 0x0264 | ADC DRC Limiter High Output at Limiter Threshold                |
| AC_ADC_DRC_LOPL     | 0x0268 | ADC DRC Limiter Low Output at Limiter Threshold                 |
| AC_ADC_DRC_HET      | 0x026C | ADC DRC Expander Threshold High Setting Register                |
| AC_ADC_DRC_LET      | 0x0270 | ADC DRC Expander Threshold Low Setting Register                 |
| AC_ADC_DRC_HKE      | 0x0274 | ADC DRC Expander Slope High Setting Register                    |

| Register Name          | Offset | Description                                                |
|------------------------|--------|------------------------------------------------------------|
| AC_ADC_DRC_LKE         | 0x0278 | ADC DRC Expander Slope Low Setting Register                |
| AC_ADC_DRC_HOPE        | 0x027C | ADC DRC Expander High Output at Expander Threshold         |
| AC_ADC_DRC_LOPE        | 0x0280 | ADC DRC Expander Low Output at Expander Threshold          |
| AC_ADC_DRC_HKN         | 0x0284 | ADC DRC Linear Slope High Setting Register                 |
| AC_ADC_DRC_LKN         | 0x0288 | ADC DRC Linear Slope Low Setting Register                  |
| AC_ADC_DRC_SFHAT       | 0x028C | ADC DRC Smooth filter Gain High Attack Time Coef Register  |
| AC_ADC_DRC_SFLAT       | 0x0290 | ADC DRC Smooth filter Gain Low Attack Time Coef Register   |
| AC_ADC_DRC_SFVRT       | 0x0294 | ADC DRC Smooth filter Gain High Release Time Coef Register |
| AC_ADC_DRC_SFLRT       | 0x0298 | ADC DRC Smooth filter Gain Low Release Time Coef Register  |
| AC_ADC_DRC_MXGHS       | 0x029C | ADC DRC MAX Gain High Setting Register                     |
| AC_ADC_DRC_MXGLS       | 0x02A0 | ADC DRC MAX Gain Low Setting Register                      |
| AC_ADC_DRC_MNGLS       | 0x02A4 | ADC DRC MIN Gain High Setting Register                     |
| AC_ADC_DRC_MXGLS       | 0x02A8 | ADC DRC MIN Gain Low Setting Register                      |
| AC_ADC_DRC_EPSHC       | 0x02AC | ADC DRC Expander Smooth Time High Coef Register            |
| AC_ADC_DRC_EPSLC       | 0x02B0 | ADC DRC Expander Smooth Time Low Coef Register             |
| AC_ADC_DRC_HPFHGAIN    | 0x02B8 | ADC DRC HPF Gain High Coef Register                        |
| AC_ADC_DRC_HPFLGAIN    | 0x02BC | ADC DRC HPF Gain Low Coef Register                         |
| Analog Domain Register |        |                                                            |
| ADC1_REG               | 0x0300 | ADC1 Analog Control Register                               |
| ADC2_REG               | 0x0304 | ADC2 Analog Control Register                               |
| ADC3_REG               | 0x0308 | ADC3 Analog Control Register                               |
| DAC_REG                | 0x0310 | DAC Analog Control Register                                |
| MICBIAS_REG            | 0x0318 | MICBIAS Analog Control Register                            |
| RAMP_REG               | 0x031C | BIAS Analog Control Register                               |
| BIAS_REG               | 0x0320 | BIAS Analog Control Register                               |
| ADC5_REG               | 0x0330 | ADC5 Analog Control Register                               |

### 8.4.6 Register Description

#### 8.4.6.1 0x0000 DAC Digital Part Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: AC_DAC_DPC                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31             | R/W        | 0x0         | EN_DA<br>DAC Digital Part Enable<br>0: Disabled<br>1: Enabled                                                                                                                   |
| 30:29          | /          | /           | /                                                                                                                                                                               |
| 28:25          | R/W        | 0x0         | MODQU<br>Internal DAC Quantization Levels<br>Levels = $[7*(21 + MODQU[3:0])]/128$<br>Default levels = $7*21/128 = 1.15$                                                         |
| 24             | R/W        | 0x0         | DWA<br>DWA Function Disable<br>0: Enabled<br>1: Disabled                                                                                                                        |
| 23:19          | /          | /           | /                                                                                                                                                                               |
| 18             | R/W        | 0x0         | HPF_EN<br>High Pass Filter Enable<br>0: Disabled<br>1: Enabled                                                                                                                  |
| 17:12          | R/W        | 0x0         | DVOL<br>Digital volume control: DVC, ATT = DVC[5:0]*(-1.16 dB)<br>64 steps, -1.16 dB/step                                                                                       |
| 11:1           | /          | /           | /                                                                                                                                                                               |
| 0              | R/W        | 0x0         | HUB_EN<br>Audio Hub Enable<br>The bit takes effect only when the EN_DA is set to 1.<br>System Domain: Audio Codec/I2S1/I2S2/OWA TXFIFO Hub Enable.<br>0: Disabled<br>1: Enabled |

#### 8.4.6.2 0x0004 DAC Volume Control Register (Default Value: 0x0000\_A0A0)

| Offset: 0x0004 |            |             | Register Name: DAC_VOL_CTRL                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                            |
| 31:17          | /          | /           | /                                                                                                                                                                                                      |
| 16             | R/W        | 0x0         | DAC_VOL_SEL<br>DAC Volume Control Selection Enable<br>0: Disabled<br>1: Enabled                                                                                                                        |
| 15:8           | R/W        | 0xA0        | DAC_VOL_L<br>DAC left channel volume<br>(-119.25 dB to 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F = -0.75 dB<br>0xA0 = 0 dB<br>0xA1 = 0.75 dB<br>...<br>0xFF = 71.25 dB  |
| 7:0            | R/W        | 0xA0        | DAC_VOL_R<br>DAC right channel volume<br>(-119.25 dB To 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F = -0.75 dB<br>0xA0 = 0 dB<br>0xA1 = 0.75 dB<br>...<br>0xFF = 71.25 dB |

## 8.4.6.3 0x0010 DAC FIFO Control Register (Default Value: 0x0000\_4000)

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                          |
| 31:29          | R/W        | 0x0         | <p>DAC_FS<br/>Sample Rate of DAC<br/>000: 48 kHz<br/>010: 24 kHz<br/>100: 12 kHz<br/>110: 192 kHz<br/>001: 32 kHz<br/>011: 16 kHz<br/>101: 8 kHz<br/>111: 96 kHz<br/>44.1 kHz/22.05 kHz/11.025 kHz can be supported by Audio PLL<br/>Configure Bit</p>                               |
| 28             | R/W        | 0x0         | <p>FIR_VER<br/>FIR Version<br/>0: 64-Tap FIR<br/>1: 32-Tap FIR</p>                                                                                                                                                                                                                   |
| 27             | /          | /           | /                                                                                                                                                                                                                                                                                    |
| 26             | R/W        | 0x0         | <p>SEND_LASAT<br/>Audio sample select when TX FIFO underrun<br/>0: Sending zero<br/>1: Sending the last audio sample</p>                                                                                                                                                             |
| 25:24          | R/W        | 0x0         | <p>FIFO_MODE<br/>For 20-bit transmitted audio sample:<br/>00/10: FIFO_I[19:0] = {TXDATA[31:12]}<br/>01/11: FIFO_I[19:0] = {TXDATA[19:0]}<br/>For 16-bit transmitted audio sample:<br/>00/10: FIFO_I[19:0] = {TXDATA[31:16], 4'b0}<br/>01/11: FIFO_I[19:0] = {TXDATA[15:0], 4'b0}</p> |
| 23             | /          | /           | /                                                                                                                                                                                                                                                                                    |

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                          |
| 22:21          | R/W        | 0x0         | <p>DAC_DRQ_CLR_CNT</p> <p>When TX FIFO available room is less than or equal N, the DRQ request will be de-asserted. N is defined here:</p> <ul style="list-style-type: none"> <li>00: IRQ/DRQ de-asserted when WLEVEL &gt; TXTL</li> <li>01: 4</li> <li>10: 8</li> <li>11: 16</li> </ul>                             |
| 20:15          | /          | /           | /                                                                                                                                                                                                                                                                                                                    |
| 14:8           | R/W        | 0x40        | <p>TX_TRIG_LEVEL</p> <p>TX FIFO Empty Trigger Level (TXTL[12:0])</p> <p>Interrupt and DMA request trigger level for TX FIFO normal condition.</p> <p>IRQ/DRQ generated when WLEVEL ≤ TXTL</p> <p><b>Note: WLEVEL represents the number of valid samples in the TX FIFO. Only TXTL[6:0] valid when TXMODE = 0</b></p> |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                                                                    |
| 6              | R/W        | 0x0         | <p>DAC_MONO_EN</p> <p>DAC Mono Enable</p> <p>0: Stereo, 64 levels FIFO</p> <p>1: Mono, 128 levels FIFO</p> <p>When enabled, L &amp; R channel send the same data.</p>                                                                                                                                                |
| 5              | R/W        | 0x0         | <p>TX_SAMPLE_BITS</p> <p>Transmitting Audio Sample Resolution</p> <p>0: 16 bits</p> <p>1: 20 bits</p>                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | <p>DAC_DRQ_EN</p> <p>DAC FIFO Empty DRQ Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                                                                                                                                                                                              |
| 3              | R/W        | 0x0         | <p>DAC_IRQ_EN</p> <p>DAC FIFO Empty IRQ Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                                                                                                                                                                                              |

| Offset: 0x0010 |            |             | Register Name: AC_DAC_FIFOC                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 2              | R/W        | 0x0         | FIFO_UNDERRUN_IRQ_EN<br>DAC FIFO Underrun IRQ Enable<br>0: Disabled<br>1: Enabled |
| 1              | R/W        | 0x0         | FIFO_OVERRUN_IRQ_EN<br>DAC FIFO Overrun IRQ Enable<br>0: Disabled<br>1: Enabled   |
| 0              | R/WC       | 0x0         | FIFO_FLUSH<br>DAC FIFO Flush<br>Write '1' to flush TX FIFO, self clear to '0'     |

#### 8.4.6.4 0x0014 DAC FIFO Status Register (Default Value: 0x0080\_8008)

| Offset: 0x0014 |            |             | Register Name: AC_DAC_FIFOS                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:24          | /          | /           | /                                                                                                                                                                                                |
| 23             | R          | 0x1         | TX_EMPTY<br>TX FIFO Empty<br>0: No room for new sample in TX FIFO<br>1: More than one room for new sample in TX FIFO ( $\geq 1$ word)                                                            |
| 22:8           | R          | 0x80        | TXE_CNT<br>TX FIFO Empty Space Word Counter                                                                                                                                                      |
| 7:4            | /          | /           | /                                                                                                                                                                                                |
| 3              | R/W1C      | 0x1         | TXE_INT<br>TX FIFO Empty Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Empty Pending Interrupt<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails. |
| 2              | R/W1C      | 0x0         | TXU_INT<br>TX FIFO Underrun Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Underrun Pending Interrupt<br>Write '1' to clear this interrupt                                              |

| Offset: 0x0014 |            |             | Register Name: AC_DAC_FIFOS                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                              |
| 1              | R/W1C      | 0x0         | <p>TXO_INT</p> <p>TX FIFO Overrun Pending Interrupt</p> <p>0: No Pending Interrupt</p> <p>1: FIFO Overrun Pending Interrupt</p> <p>Write ‘1’ to clear this interrupt</p> |
| 0              | /          | /           | /                                                                                                                                                                        |

#### 8.4.6.5 0x0020 DAC TX DATA Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: AC_DAC_TXDATA                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:0           | W          | 0x0         | <p>TX_DATA</p> <p>Write the transmitting left and right channel sample data to this register one by one. Write the left channel sample data first and then the right channel sample.</p> |

#### 8.4.6.6 0x0024 DAC TX Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: AC_DAC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:0           | R/W        | 0x0         | <p>TX_CNT</p> <p>TX Sample Counter</p> <p>The audio sample number of sending into TXFIFO.</p> <p>When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count from this initial value.</p> <p><b>Note: It is used for Audio/Video Synchronization.</b></p> |

## 8.4.6.7 0x0028 DAC Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: AC_DAC_DG                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 31:12          | /          | /           | /                                                                                                                                                                                             |
| 11             | R/W        | 0x0         | DAC_MODU_SELECT<br>DAC Modulator Debug<br>0: DAC Modulator Normal Mode<br>1: DAC Modulator Debug Mode                                                                                         |
| 10:9           | R/W        | 0x0         | DAC_PATTERN_SELECT<br>DAC Pattern Select<br>00: Normal (Audio sample from TX FIFO)<br>01: -6 dB Sin wave<br>10: -60 dB Sin wave<br>11: Silent wave                                            |
| 8              | R/W        | 0x0         | CODEC_CLK_SELECT<br>CODEC Clock Source Select<br>0: CODEC clock from PLL<br>1: CODEC clock from OSC (for Debug)                                                                               |
| 7              | /          | /           | /                                                                                                                                                                                             |
| 6              | R/W        | 0x0         | DA_SWP<br>DAC Output Channel Swap Enable<br>0: Disabled<br>1: Enabled                                                                                                                         |
| 5:3            | /          | /           | /                                                                                                                                                                                             |
| 2:0            | R/W        | 0x0         | ADDA_LOOP_MODE<br>ADDA Loop Mode Select<br>000: Disabled<br>001: ADDA LOOP MODE DACL/DACR is connected to ADC1/ADC2<br>010: ADDA LOOP MODE DACL/DACR is connected to ADC3<br>Others: Reserved |

**8.4.6.8 0x0030 ADC FIFO Control Register (Default Value: 0x0000\_0400)**

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                          |
| 31:29          | R/W        | 0x0         | <p>ADFS<br/>Sample Rate of ADC<br/>000: 48 kHz<br/>010: 24 kHz<br/>100: 12 kHz<br/>110: Reserved<br/>001: 32 kHz<br/>011: 16 kHz<br/>101: 8 kHz<br/>111: Reserved<br/>44.1 kHz/22.05 kHz/11.025 kHz can be supported by Audio PLL Configure Bit.</p> |
| 28             | R/W        | 0x0         | <p>EN_AD<br/>ADC Digital Part Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                              |
| 27:26          | R/W        | 0x0         | <p>ADCFDT<br/>ADC FIFO delay time for writing data after EN_AD<br/>00: 5 ms<br/>01: 10 ms<br/>10: 20 ms<br/>11: 30 ms</p>                                                                                                                            |
| 25             | R/W        | 0x0         | <p>ADCDFEN<br/>ADC FIFO delay function for writing data after EN_AD<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                               |

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 24             | R/W        | 0x0         | <p>RX_FIFO_MODE</p> <p>RX FIFO Output Mode (Mode 0, 1)</p> <p>0: Expanding '0' at LSB of TX FIFO register</p> <p>1: Expanding received sample sign bit at MSB of TX FIFO register</p> <p>For 20-bit received audio sample:</p> <p>Mode 0: RXDATA[31:0] = {FIFO_O[19:0], 12'h0}</p> <p>Mode 1: RXDATA[31:0] = {12{FIFO_O[19]}, FIFO_O[19:0]}</p> <p>For 16-bit received audio sample:</p> <p>Mode 0: RXDATA[31:0] = {FIFO_O[19:4], 16'h0}</p> <p>Mode 1: RXDATA[31:0] = {16{FIFO_O[19]}, FIFO_O[19:4]}</p> |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21             | R/W        | 0x0         | <p>RX_SYNC_EN_START</p> <p>The bit takes effect only when RX_SYNC_EN is set to 1.</p> <p>System Domain: Audio codec/I2S1/I2S2/DMIC Synchronize Enable Start.</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                                                                                                                                                                                                                                                                     |
| 20             | R/W        | 0x0         | <p>RX_SYNC_EN</p> <p>Audiocodec RX Synchronize Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16             | R/W        | 0x0         | <p>RX_SAMPLE_BITS</p> <p>Receiving Audio Sample Resolution</p> <p>0: 16 bits</p> <p>1: 20 bits</p>                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:4           | R/W        | 0x40        | <p>RX_FIFO_TRG_LEVEL</p> <p>RX FIFO Trigger Level (RXTL[5:0])</p> <p>Interrupt and DMA request trigger level for RX FIFO normal condition</p> <p>IRQ/DRQ generated when WLEVEL &gt; RXTL[5:0]</p> <p><b>Note: WLEVEL represents the number of valid samples in the RX FIFO.</b></p>                                                                                                                                                                                                                       |

| Offset: 0x0030 |            |             | Register Name: AC_ADC_FIFOC                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 3              | R/W        | 0x0         | ADC_DRQ_EN<br>ADC FIFO Data Available DRQ Enable<br>0: Disabled<br>1: Enabled      |
| 2              | R/W        | 0x0         | ADC_IRQ_EN<br>ADC FIFO Data Available IRQ Enable<br>0: Disabled<br>1: Enabled      |
| 1              | R/W        | 0x0         | ADC_OVERRUN_IRQ_EN<br>ADC FIFO Overrun IRQ Enable<br>0: Disabled<br>1: Enabled     |
| 0              | R/WC       | 0x0         | ADC_FIFO_FLUSH<br>ADC FIFO Flush<br>Write '1' to flush TX FIFO, self clear to '0'. |

#### 8.4.6.9 0x0034 ADC Volume Control1 Register (Default Value: 0xA0A0\_A0A0)

| Offset: 0x0034 |            |             | Register Name: ADC_VOL_CTRL1                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:24          | R/W        | 0xA0        | Reserved                                                                                                                                                                                     |
| 23:16          | R/W        | 0xA0        | ADC3_VOL<br>ADC3 channel volume<br>(-119.25 dB To 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |

| Offset: 0x0034 |            |             | Register Name: ADC_VOL_CTRL1                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 15:8           | R/W        | 0xA0        | ADC2_VOL<br>ADC2 channel volume<br>(-119.25 dB To 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |
| 7:0            | R/W        | 0xA0        | ADC1_VOL<br>ADC1 channel volume<br>(-119.25 dB To 71.25 dB, 0.75 dB/Step)<br>0x00: Mute<br>0x01: -119.25 dB<br>...<br>0x9F: -0.75 dB<br>0xA0: 0 dB<br>0xA1: 0.75 dB<br>...<br>0xFF: 71.25 dB |

#### 8.4.6.10 0x0038 ADC FIFO Status Register (Default Value: 0x0000\_0001)

| Offset: 0x0038 |            |             | Register Name: AC_ADC_FIFOS                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31:24          | /          | /           | /                                                                                                             |
| 23             | R          | 0x0         | RXA<br>RX FIFO Available<br>0: No available data in RX FIFO<br>1: More than one sample in RX FIFO (>= 1 word) |
| 22:17          | /          | /           | /                                                                                                             |
| 16:8           | R          | 0x0         | RXA_CNT<br>RX FIFO Available Sample Word Counter                                                              |

| Offset: 0x0038 |            |             | Register Name: AC_ADC_FIFOS                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 7:4            | /          | /           | /                                                                                                                                                                                                              |
| 3              | R/W1C      | 0x0         | <p>RXA_INT<br/>RX FIFO Data Available Pending Interrupt<br/>0: No Pending IRQ<br/>1: Data Available Pending IRQ<br/>Write '1' to clear this interrupt or automatic clear if the interrupt condition fails.</p> |
| 2              | /          | /           | /                                                                                                                                                                                                              |
| 1              | R/W1C      | 0x0         | <p>RXO_INT<br/>RX FIFO Overrun Pending Interrupt<br/>0: No Pending IRQ<br/>1: FIFO Overrun Pending IRQ<br/>Write '1' to clear this interrupt.</p>                                                              |
| 0              | R          | 0x1         | Reserved                                                                                                                                                                                                       |

#### 8.4.6.11 0x0040 ADC RX DATA Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: AC_ADC_RXDATA                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31:0           | R          | 0x0         | <p>RX_DATA<br/>RX Sample<br/>The host can get one sample by reading this register. The left channel sample data comes first and then the right channel sample.</p> |

#### 8.4.6.12 0x0044 ADC RX Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: AC_ADC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | <p>RX_CNT<br/>RX Sample Counter</p> <p>The audio sample number of writing into RXFIFO. When one sample is written by Digital Audio Engine, the RX sample counter register increases by one. The RX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count from this initial value.</p> <p><b>Note:</b> It is used for Audio/Video Synchronization.</p> |

#### 8.4.6.13 0x004C ADC Debug Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: AC_ADC_DG_REG                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:26          | /          | /           | /                                                                                                                                                     |
| 25             | R/W        | 0x0         | <p>AD_SWP2<br/>ADC output channel swap enable (for digital filter)</p> <p>0: Disabled<br/>1: Enabled</p> <p><b>Note:</b> ADC3 and ADC4 swap data.</p> |
| 24             | R/W        | 0x0         | <p>AD_SWP1<br/>ADC output channel swap enable (for digital filter)</p> <p>0: Disabled<br/>1: Enabled</p> <p><b>Note:</b> ADC1 and ADC2 swap data.</p> |
| 23:0           | /          | /           | /                                                                                                                                                     |

#### 8.4.6.14 0x0050 ADC Digital Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: ADC_DIG_CTRL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:18          | /          | /           | /                           |

| Offset: 0x0050 |            |             | Register Name: ADC_DIG_CTRL                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 17             | R/W        | 0x0         | ADC3_VOL_EN<br>ADC3 Volume Control Enable<br>0: Disabled<br>1: Enabled                                     |
| 16             | R/W        | 0x0         | ADC1_2_VOL_EN<br>ADC1/2 Volume Control Enable<br>0: Disabled<br>1: Enabled                                 |
| 15:3           | /          | /           | /                                                                                                          |
| 2:0            | R/W        | 0x0         | ADC_CHANNEL_EN<br>Bit 3: ADC4 enabled<br>Bit 2: ADC3 enabled<br>Bit 1: ADC2 enabled<br>Bit 0: ADC1 enabled |

#### 8.4.6.15 0x0054 VRA1 Speedup Down Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: VRA1SPEEDUP_DOWN_CTRL                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:5           | /          | /           | /                                                                                                                                                                                                              |
| 4              | R          | 0x0         | VRA1SPEEDUP_DOWN_STATE<br>Only if VAR1SPEEDUP_DOWN_Further_CTRL (0x310[22]) is set 0,<br>VAR1Speedup Down State is valid.<br>0: VAR1Speedup_Down does not work.<br>1: VAR1Speedup_Down works.                  |
| 3:2            | /          | /           | /                                                                                                                                                                                                              |
| 1              | R/W        | 0x0         | VRA1SPEEDUP_DOWN_CTRL<br>VAR1Speedup Down Manual Control Enable<br>0: Disabled. VAR1Speedup Down converts to 1 after the bus rst<br>releases 32 ms.<br>1: Enabled. VAR1Speedup Down converts to 1 immediately. |

| Offset: 0x0054 |            |             | Register Name: VRA1SPEEDUP_DOWN_CTRL                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 0              | R/W        | 0x0         | VRA1SPEEDUP_DOWN_RST_CTRL<br>VAR1Speedup Down RST Manual Control Enable<br>0: Disabled. VAR1Speedup Down converts to 1 after the bus rst releases 32 ms.<br>1: Enabled. VAR1Speedup Down reset 0 immediately. |

#### 8.4.6.16 0x00F0 DAC DAP Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00F0 |            |             | Register Name: AC_DAC_DAP_CTR                                  |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31             | R/W        | 0x0         | DDAP_EN<br>DAP for DRC enable<br>0: Bypassed<br>1: Enabled     |
| 30             | /          | /           | /                                                              |
| 29             | R/W        | 0x0         | DDAP_DRC_EN<br>DRC enable control<br>0: Disabled<br>1: Enabled |
| 28             | R/W        | 0x0         | DDAP_HPF_EN<br>HPF enable control<br>0: Disabled<br>1: Enabled |
| 27:0           | /          | /           | /                                                              |

#### 8.4.6.17 0x00F8 ADC DAP Control Register (Default Value: 0x0000\_0000)

| Offset: 0x00F8 |            |             | Register Name: AC_ADC_DAP_CTR                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31             | R/W        | 0x0         | ADC_DAP0_EN (control the DAP of ADC1/2)<br>DAP for ADC enable<br>0: Bypassed<br>1: Enabled |
| 30             | /          | /           | /                                                                                          |

| Offset: 0x00F8 |            |             | Register Name: AC_ADC_DAP_CTR                                       |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 29             | R/W        | 0x0         | ADC_DRC0_EN<br>ADC DRC0 enable control<br>0: Disabled<br>1: Enabled |
| 28             | R/W        | 0x0         | ADC_HPF0_EN<br>ADC HPF0 enable control<br>0: Disabled<br>1: Enabled |
| 27             | R/W        | 0x0         | ADC_DAP1_EN (control the DAP of ADC3)<br>ADC DAP1 enable control    |
| 26             | /          | /           | /                                                                   |
| 25             | R/W        | 0x0         | ADC_DRC1_EN<br>ADC DRC1 enable control<br>0: Disabled<br>1: Enabled |
| 24             | R/W        | 0x0         | ADC_HPF1_EN<br>ADC HPF1 enable control<br>0: Disabled<br>1: Enabled |
| 23:0           | /          | /           | /                                                                   |

#### 8.4.6.18 0x0100 DAC DRC High HPF Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0100 |            |             | Register Name: AC_DAC_DRC_HHPFC                      |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:11          | /          | /           | /                                                    |
| 10:0           | R/W        | 0xFF        | HPF coefficient setting and the data is 3.24 format. |

#### 8.4.6.19 0x0104 DAC DRC Low HPF Coef Register (Default Value: 0x0000\_FAC1)

| Offset: 0x0104 |            |             | Register Name: AC_DAC_DRC_LHPFC |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |

| Offset: 0x0104 |            |             | Register Name: AC_DAC_DRC_LHPFC                      |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 15:0           | R/W        | 0xFAC1      | HPF coefficient setting and the data is 3.24 format. |

#### 8.4.6.20 0x0108 DAC DRC Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0108 |            |             | Register Name: AC_DAC_DRC_CTRL                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                |
| 15             | R          | 0x0         | DRC delay buffer data output state when The DRC delay function is enabled and the DRC function is disabled. After disabling the DRC function and this bit goes to 0, write the DRC delay function bit to 0.<br>0: Not completed<br>1: Completed                                  |
| 14:10          | /          | /           | /                                                                                                                                                                                                                                                                                |
| 13:8           | R/W        | 0x0         | Signal delay time setting<br>6'h00: (8x1) fs<br>6'h01: (8x2) fs<br>6'h02: (8x3) fs<br>-----<br>6'h2e: (8*47) fs<br>6'h2f: (8*48) fs<br>6'h30 -- 6'h3f: (8*48) fs<br>Delay time = 8*(n + 1) fs, n<6'h30;<br>When the delay function is disabled, the signal delay time is unused. |
| 7              | R/W        | 0x1         | DAC_DRC_DELAY_BUF_EN<br>The delay buffer use or not when the DRC is disabled and the DRC buffer data output completely.<br>0: Do not use the buffer.<br>1: Use the buffer.                                                                                                       |
| 6              | R/W        | 0x0         | DAC_DRC_GAIN_MAX_LIMIT_EN<br>DRC gain max limit enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                              |

| Offset: 0x0108 |            |             | Register Name: AC_DAC_DRC_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5              | R/W        | 0x0         | <p>DAC_DRC_GAIN_MIN_LIMIT_EN<br/>DRC gain min limit enable<br/>When this function is enabled, it will overwrite the noise detect function.<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                              |
| 4              | R/W        | 0x0         | <p>DAC_DRC_DETECT_NOISE_EN<br/>Control the DRC to detect noise when ET is enabled.<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                      |
| 3              | R/W        | 0x0         | <p>DAC_DRC_SIGNAL_FUNC_SEL<br/>Signal function select<br/>0: RMS filter<br/>1: Peak filter<br/>When the signal function selects the Peak filter, the RMS parameter is unused. (AC_DRC_LRMSHAT, AC_DRC_LRMSLAT, AC_DRC_LRMASHAT, AC_DRC_LRMSLAT)<br/>When the signal function selects the RMS filter, the Peak filter parameter is unused. (AC_DRC_LPFBAT, AC_DRC_LPFLAT, AC_DRC_RPFBAT, AC_DRC_RPFLAT, AC_DRC_LPFBRT, AC_DRC_LPFLRT, AC_DRC_RPFBRT, and AC_DRC_RPFLRT)</p> |
| 2              | R/W        | 0x0         | <p>DAC_DRC_DELAY_FUNC_EN<br/>Delay function enable<br/>0: Disabled<br/>1: Enabled<br/>When the bit is disabled, the signal delay time is unused.</p>                                                                                                                                                                                                                                                                                                                       |
| 1              | R/W        | 0x0         | <p>DAC_DRC_LT_EN<br/>DRC LT enable<br/>0: Disabled<br/>1: Enabled<br/>When the bit is disabled, KI and OPL parameter is unused.</p>                                                                                                                                                                                                                                                                                                                                        |
| 0              | R/W        | 0x0         | <p>DAC_DRC_ET_EN<br/>DRC ET enable<br/>0: Disabled<br/>1: Enabled<br/>When the bit is disabled, Ke and OPE parameter is unused.</p>                                                                                                                                                                                                                                                                                                                                        |

#### 8.4.6.21 0x010C DAC DRC Left Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x010C |            |             | Register Name: AC_DAC_DRC_LPFHAT                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:11          | /          | /           | /                                                                                                                                                                                      |
| 10:0           | R/W        | 0x000B      | DAC_DRC_LPFHAT<br>The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.22 0x0110 DAC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0110 |            |             | Register Name: AC_DAC_DRC_LPFLAT                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                                      |
| 15:0           | R/W        | 0x77BF      | DAC_DRC_LPFLAT<br>The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.23 0x0114 DAC DRC Right Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x0114 |            |             | Register Name: AC_DAC_DRC_RPFHAT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                       |
| 15:0           | R/W        | 0xB         | DAC_DRC_RPFHAT<br>The right peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.24 0x0118 DAC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0118 |            |             | Register Name: AC_DAC_DRC_RPFLAT |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:16          | /          | /           | /                                |

| Offset: 0x0118 |            |             | Register Name: AC_DAC_DRC_RPFLAT                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 15:0           | R/W        | 0x77BF      | DAC_DRC_RPFLAT<br>The left peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.25 0x011C DAC DRC Left Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x011C |            |             | Register Name: AC_DAC_DRC_LPFHRT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:11          | /          | /           | /                                                                                                                                                                                       |
| 10:0           | R/W        | 0x00FF      | DAC_DRC_LPFHRT<br>The left peak filter release time parameter setting, which is determined by the equation that RT = exp (-2.2Ts/tr). The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.26 0x0120 DAC DRC Left Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0120 |            |             | Register Name: AC_DAC_DRC_LPFLRT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                       |
| 15:0           | R/W        | 0xE1F8      | DAC_DRC_LPFLRT<br>The left peak filter release time parameter setting, which is determined by the equation that RT = exp (-2.2Ts/tr). The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.27 0x0124 DAC DRC Right Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0124 |            |             | Register Name: AC_DAC_DRC_RPFHRT |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:16          | /          | /           | /                                |

| Offset: 0x0124 |            |             | Register Name: AC_DAC_DRC_RPFHRT                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 15:0           | R/W        | 0xFF        | DAC_DRC_RPFHRT<br>The right peak filter release time parameter setting, which is determined by the equation that RT = exp (-2.2Ts/tr). The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.28 0x0128 DAC DRC Right Peak filter Low Release Time Coef Register(Default Value: 0x0000\_E1F8)

| Offset: 0x0128 |            |             | Register Name: AC_DAC_DRC_RPFLRT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                       |
| 15:0           | R/W        | 0xE1F8      | DAC_DRC_RPFLRT<br>The right peak filter release time parameter setting, which is determined by the equation that AT = exp(-2.2Ts/tr). The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.29 0x012C DAC DRC Left RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x012C |            |             | Register Name: AC_DAC_DRC_LRMSHAT                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31:11          | /          | /           | /                                                                                                                                                                                         |
| 10:0           | R/W        | 0x0001      | DAC_DRC_LRMSHAT<br>The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tav). The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.30 0x0130 DAC DRC Left RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

| Offset: 0x0130 |            |             | Register Name: AC_DAC_DRC_LRMSLAT |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:16          | /          | /           | /                                 |

| Offset: 0x0130 |            |             | Register Name: AC_DAC_DRC_LRMSLAT                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 15:0           | R/W        | 0x2BAF      | DAC_DRC_LRMSLAT<br>The left RMS filter average time parameter setting, which is determined by the equation that $AT = 1 - \exp(-2.2Ts/tav)$ . The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.31 0x0134 DAC DRC Right RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x0134 |            |             | Register Name: AC_DAC_DRC_RRMSHAT                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                                                               |
| 15:0           | R/W        | 0x2BAF      | DAC_DRC_RRMSHAT<br>The right RMS filter average time parameter setting, which is determined by the equation that $AT = 1 - \exp(-2.2Ts/tav)$ . The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.32 0x0138 DAC DRC Right RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

| Offset: 0x0138 |            |             | Register Name: AC_DAC_DRC_RRMSLAT                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                                                               |
| 15:0           | R/W        | 0x2BAF      | DAC_DRC_RRMSLAT<br>The right RMS filter average time parameter setting, which is determined by the equation that $AT = 1 - \exp(-2.2Ts/tav)$ . The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.33 0x013C DAC DRC Compressor Threshold High Setting Register (Default Value: 0x0000\_06A4)

| Offset: 0x013C |            |             | Register Name: AC_DAC_DRC_HCT |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x013C |            |             | Register Name: AC_DAC_DRC_HCT                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 15:0           | R/W        | 0x06A4      | DAC_DRC_HCT<br>The compressor threshold setting, which is set by the equation that $CTin = -CT/6.0206$ . The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.34 0x0140 DAC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_D3C0)

| Offset: 0x0140 |            |             | Register Name: AC_DAC_DRC_LCT                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                          |
| 15:0           | R/W        | 0xD3C0      | DAC_DRC_LCT<br>The compressor threshold setting, which is set by the equation that $CTin = -CT/6.0206$ . The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.35 0x0144 DAC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_0080)

| Offset: 0x0144 |            |             | Register Name: AC_DAC_DRC_HKC                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                                                              |
| 15:0           | R/W        | 0x0080      | DAC_DRC_HKC<br>The slope of the compressor, which is determined by the equation that $Kc = 1/R$ . R is the ratio of the compressor, which is always an integer. The format is 8.24. (The default value is 2:1) |

#### 8.4.6.36 0x0148 DAC DRC Compressor Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0148 |            |             | Register Name: AC_DAC_DRC_LKC |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x0148 |            |             | Register Name: AC_DAC_DRC_LKC                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKC<br>The slope of the compressor, which is determined by the equation that $K_c = 1/R$ . R is the ratio of the compressor, which is always an integer. The format is 8.24. (The default value is 2:1) |

#### 8.4.6.37 0x014C DAC DRC Compressor High Output at Compressor Threshold Register (Default Value: 0x0000\_F95B)

| Offset: 0x014C |            |             | Register Name: AC_DAC_DRC_HOPC                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                  |
| 15:0           | R/W        | 0xF95B      | DAC_DRC_HOPC<br>The output of the compressor, which is determined by the equation $-OPC/6.0206$ . The format is 8.24 (The default value is -40 dB) |

#### 8.4.6.38 0x0150 DAC DRC Compressor Low Output at Compressor Threshold Register (Default Value: 0x0000\_2C3F)

| Offset: 0x0150 |            |             | Register Name: AC_DAC_DRC_LOPC                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                  |
| 15:0           | R/W        | 0x2C3F      | DAC_DRC_LOPC<br>The output of the compressor, which is determined by the equation $OPC/6.0206$ . The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.39 0x0154 DAC DRC Limiter Threshold High Setting Register (Default Value: 0x0000\_01A9)

| Offset: 0x0154 |            |             | Register Name: AC_DAC_DRC_HLT                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                      |
| 15:0           | R/W        | 0x01A9      | DAC_DRC_HLT<br>The limiter threshold setting, which is set by the equation that $LTh = -LT/6.0206$ , The format is 8.24. (The default value is -10 dB) |

**8.4.6.40 0x0158 DAC DRC Limiter Threshold Low Setting Register (Default Value: 0x0000\_34F0)**

| Offset: 0x0158 |            |             | Register Name: AC_DAC_DRC_LLT                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                          |
| 15:0           | R/W        | 0x34F0      | DAC_DRC_LLT<br>The limiter threshold setting, which is set by the equation that $L_{Tin} = -LT/6.0206$ . The format is 8.24. (The default value is -10 dB) |

**8.4.6.41 0x015C DAC DRC Limiter Slope High Setting Register (Default Value: 0x0000\_0005)**

| Offset: 0x015C |            |             | Register Name: AC_DAC_DRC_HKI                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                                                                                          |
| 15:0           | R/W        | 0x0005      | DAC_DRC_HKI<br>The slope of the limiter which is determined by the equation that $KI = 1/R$ . R is the ratio of the limiter, which is always an integer. The format is 8.24. (The default value is <50:1>) |

**8.4.6.42 0x0160 DAC DRC Limiter Slope Low Setting Register (Default Value: 0x0000\_1EB8)**

| Offset: 0x0160 |            |             | Register Name: AC_DAC_DRC_LKI                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                           |
| 15:0           | R/W        | 0x1EB8      | DAC_DRC_LKI<br>The slope of the limiter, which is determined by the equation that $KI = 1/R$ . R is the ratio of the limiter, which is always an integer. The format is 8.24. (The default value is <50:1>) |

#### 8.4.6.43 0x0164 DAC DRC Limiter High Output at Limiter Threshold Register (Default Value: 0x0000\_FBD8)

| Offset: 0x0164 |            |             | Register Name: AC_DAC_DRC_HOPL                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                        |
| 15:0           | R/W        | 0xFBD8      | DAC_DRC_HOPL<br>The output of the limiter, which is determined by equation OPT/6.0206. The format is 8.24. (The default value is -25 dB) |

#### 8.4.6.44 0x0168 DAC DRC Limiter Low Output at Limiter Threshold Register (Default Value: 0x0000\_FBA7)

| Offset: 0x0168 |            |             | Register Name: AC_DAC_DRC_LOPL                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                        |
| 15:0           | R/W        | 0xFBA7      | DAC_DRC_LOPL<br>The output of the limiter, which is determined by equation OPT/6.0206. The format is 8.24. (The default value is -25 dB) |

#### 8.4.6.45 0x016C DAC DRC Expander Threshold High Setting Register (Default Value: 0x0000\_0BA0)

| Offset: 0x016C |            |             | Register Name: AC_DAC_DRC_HET                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                     |
| 15:0           | R/W        | 0x0BA0      | DAC_DRC_HET<br>The expander threshold setting, which is set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70 dB) |

#### 8.4.6.46 0x0170 DAC DRC Expander Threshold Low Setting Register (Default Value: 0x0000\_7291)

| Offset: 0x0170 |            |             | Register Name: AC_DAC_DRC LET                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                     |
| 15:0           | R/W        | 0x7291      | DAC_DRC LET<br>The expander threshold setting, which is set by the equation that ETin = -ET/6.0206. The format is 8.24. (The default value is -70 dB) |

**8.4.6.47 0x0174 DAC DRC Expander Slope High Setting Register (Default Value: 0x0000\_0500)**

| Offset: 0x0174 |            |             | Register Name: AC_DAC_DRC_HKE                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                           |
| 13:0           | R/W        | 0x0500      | DAC_DRC_HKE<br>The slope of the expander, which is determined by the equation that $Ke = 1/R$ . R is the ratio of the expander, which is always an integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

**8.4.6.48 0x0178 DAC DRC Expander Slope Low Setting Register (Default Value: 0x0000\_0000)**

| Offset: 0x0178 |            |             | Register Name: AC_DAC_DRC_LKE                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                           |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKE<br>The slope of the expander, which is determined by the equation that $Ke = 1/R$ . R is the ratio of the expander, which is always an integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

**8.4.6.49 0x017C DAC DRC Expander High Output at Expander Threshold Register (Default Value: 0x0000\_F45F)**

| Offset: 0x017C |            |             | Register Name: AC_DAC_DRC_HOPE                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                            |
| 15:0           | R/W        | 0xF45F      | DAC_DRC_HOPE<br>The output of the expander, which is determined by equation $OPE/6.0206$ . The format is 8.24. (The default value is -70 dB) |

#### 8.4.6.50 0x0180 DAC DRC Expander Low Output at Expander Threshold Register (Default Value: 0x0000\_8D6E)

| Offset: 0x0180 |            |             | Register Name: AC_DAC_DRC_LOPE                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                        |
| 15:0           | R/W        | 0x8D6E      | DAC_DRC_LOPE<br>The output of the expander which is determined by equation OPE/6.0206. The format is 8.24. (The default value is -70 dB) |

#### 8.4.6.51 0x0184 DAC DRC Linear Slope High Setting Register (Default Value: 0x0000\_0100)

| Offset: 0x0184 |            |             | Register Name: AC_DAC_DRC_HKN                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                                                                                         |
| 15:0           | R/W        | 0x0100      | DAC_DRC_HKN<br>The slope of the linear, which is determined by the equation that $K_n = 1/R$ . R is the ratio of the linear, which is always an integer. The format is 8.24. (The default value is <1:1>) |

#### 8.4.6.52 0x0188 DAC DRC Linear Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0188 |            |             | Register Name: AC_DAC_DRC_LKN                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                                                                                         |
| 15:0           | R/W        | 0x0000      | DAC_DRC_LKN<br>The slope of the linear, which is determined by the equation that $K_n = 1/R$ . R is the ratio of the linear, which is always an integer. The format is 8.24. (The default value is <1:1>) |

#### 8.4.6.53 0x018C DAC DRC Smooth Filter Gain High Attack Time Coef Register (Default Value: 0x0000\_0002)

| Offset: 0x018C |            |             | Register Name: AC_DAC_DRC_SFHAT |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:11          | /          | /           | /                               |

| Offset: 0x018C |            |             | Register Name: AC_DAC_DRC_SFHAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 10:0           | R/W        | 0x0002      | DAC_DRC_SFHAT<br>The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 5 ms) |

#### 8.4.6.54 0x0190 DAC DRC Smooth Filter Gain Low Attack Time Coef Register (Default Value: 0x0000\_5600)

| Offset: 0x0190 |            |             | Register Name: AC_DAC_DRC_SFLAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                  |
| 15:0           | R/W        | 0x5600      | DAC_DRC_SFLAT<br>The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 5 ms) |

#### 8.4.6.55 0x0194 DAC DRC Smooth Filter Gain High Release Time Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x0194 |            |             | Register Name: AC_DAC_DRC_SFHRT                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31:11          | /          | /           | /                                                                                                                                                                                          |
| 10:0           | R/W        | 0x0000      | DAC_DRC_SFHRT<br>The gain smooth filter release time parameter setting, which is determined by the equation that RT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 200 ms) |

#### 8.4.6.56 0x0198 DAC DRC Smooth Filter Gain Low Release Time Coef Register (Default Value: 0x0000\_0F04)

| Offset: 0x0198 |            |             | Register Name: AC_DAC_DRC_SFLRT |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |

| Offset: 0x0198 |            |             | Register Name: AC_DAC_DRC_SFLRT                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 15:0           | R/W        | 0x0F04      | DAC_DRC_SFLRT<br>The gain smooth filter release time parameter setting, which is determined by the equation that $RT = 1 - \exp(-2.2T_s/tr)$ . The format is 3.24. (The default value is 200 ms) |

#### 8.4.6.57 0x019C DAC DRC MAX Gain High Setting Register (Default Value: 0x0000\_FE56)

| Offset: 0x019C |            |             | Register Name: AC_DAC_DRC_MXGHS                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                   |
| 15:0           | R/W        | 0xFE56      | DAC_DRC_MXGHS<br>The max gain setting, which is determined by equation $MXG_{in} = MXG / 6.0206$ . The format is 8.24 and must $-20 \text{ dB} < MXG < 30 \text{ dB}$ (The default value is -10 dB) |

#### 8.4.6.58 0x01A0 DAC DRC MAX Gain Low Setting Register (Default Value: 0x0000\_CBOF)

| Offset: 0x01A0 |            |             | Register Name: AC_DAC_DRC_MXGLS                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                   |
| 15:0           | R/W        | 0xCBOF      | DAC_DRC_MXGLS<br>The max gain setting, which is determined by equation $MXG_{in} = MXG / 6.0206$ . The format is 8.24 and must $-20 \text{ dB} < MXG < 30 \text{ dB}$ (The default value is -10 dB) |

#### 8.4.6.59 0x01A4 DAC DRC MIN Gain High Setting Register (Default Value: 0x0000\_F95B)

| Offset: 0x01A4 |            |             | Register Name: AC_DAC_DRC_MNGHS |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |

| Offset: 0x01A4 |            |             | Register Name: AC_DAC_DRC_MNGHS                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 15:0           | R/W        | 0xF95B      | DAC_DRC_MNGHS<br>The min gain setting, which is determined by equation MXG <sub>in</sub> =MXG/6.0206. The format is 8.24 and must -60 dB ≤ MNG ≤ -40 dB (The default value is -40 dB) |

#### 8.4.6.60 0x01A8 DAC DRC MIN Gain Low Setting Register (Default Value: 0x0000\_2C3F)

| Offset: 0x01A8 |            |             | Register Name: AC_DAC_DRC_MNGLS                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                                                     |
| 15:0           | R/W        | 0x2C3F      | DAC_DRC_MNGLS<br>The min gain setting, which is determined by equation MXG <sub>in</sub> =MNG/6.0206. The format is 8.24 and must -60 dB ≤ MNG ≤ -40 dB (The default value is -40 dB) |

#### 8.4.6.61 0x01AC DAC DRC Expander Smooth Time High Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x01AC |            |             | Register Name: AC_DAC_DRC_EPSHC                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                              |
| 31:11          | /          | /           | /                                                                                                                                                                                                                        |
| 10:0           | R/W        | 0x0000      | DAC_DRC_EPSHC<br>The gain smooth filter release and attack time parameter setting in expander region, which are determined by the equation that RT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 30 ms) |

#### 8.4.6.62 0x01B0 DAC DRC Expander Smooth Time Low Coef Register (Default Value: 0x0000\_640C)

| Offset: 0x01B0 |            |             | Register Name: AC_DAC_DRC_EPSLC |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |

| Offset: 0x01B0 |            |             | Register Name: AC_DAC_DRC_EPSLC                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                              |
| 15:0           | R/W        | 0x640C      | DAC_DRC_EPSLC<br>The gain smooth filter release and attack time parameter setting in expander region, which are determined by the equation that RT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 30 ms) |

#### 8.4.6.63 0x01B8 DAC DRC HPF Gain High Coef Register (Default Value: 0x0000\_0100)

| Offset: 0x01B8 |            |             | Register Name: AC_DAC_DRC_HPFHGAIN                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:11          | /          | /           | /                                                                               |
| 10:0           | R/W        | 0x100       | DAC_DRC_HPFHGAIN<br>The gain of HPF coefficient. The format is 3.24. (gain = 1) |

#### 8.4.6.64 0x01BC DAC DRC HPF Gain Low Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x01BC |            |             | Register Name: AC_DAC_DRC_HPFLGAIN                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:16          | /          | /           | /                                                                               |
| 15:0           | R/W        | 0x0000      | DAC_DRC_HPFLGAIN<br>The gain of HPF coefficient. The format is 3.24. (gain = 1) |

#### 8.4.6.65 0x0200 ADC DRC High HPF Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0200 |            |             | Register Name: AC_ADC_DRC_HHPFC                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:11          | /          | /           | /                                                                     |
| 10:0           | R/W        | 0xFF        | ADC_DRC_HHPFC<br>HPF coefficient setting and the data is 3.24 format. |

#### 8.4.6.66 0x0204 ADC DRC Low HPF Coef Register (Default Value: 0x0000\_FAC1)

| Offset: 0x0204 |            |             | Register Name: AC_ADC_DRC_LHPFC                      |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:16          | /          | /           | /                                                    |
| 15:0           | R/W        | 0xFAC1      | HPF coefficient setting and the data is 3.24 format. |

#### 8.4.6.67 0x0208 ADC DRC Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0208 |            |             | Register Name: AC_ADC_DRC_CTRL                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 15             | R          | 0x0         | <p>ADC_DRC_DELAY_BUF_OUTPUT_STATE</p> <p>DRC delay buffer data output state when The DRC delay function is enabled and the DRC function is disabled. After disabled DRC function and this bit goes to 0, the user should write the DRC delay function bit to 0.</p> <p>0: Not completed<br/>1: Completed</p>                                        |
| 14:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 13:8           | R/W        | 0x0         | <p>ADC_DRC_SIGNAL_DELAY_TIME_SET</p> <p>Signal delay time setting</p> <p>6'h00: (8x1) fs<br/>6'h01: (8x2) fs<br/>6'h02: (8x3) fs<br/>-----<br/>6'h2e: (8*47) fs<br/>6'h2f: (8*48) fs<br/>6'h30 -- 6'h3f: (8*48) fs</p> <p>Delay time = 8*(n + 1) fs, n &lt; 6'h30;</p> <p>When the delay function is disabled, the signal delay time is unused.</p> |
| 7              | R/W        | 0x1         | <p>ADC_DRC_DELAY_BUF_EN</p> <p>The delay buffer use or not when the DRC is disabled and the DRC buffer data output completely.</p> <p>0: Do not use the buffer<br/>1: Use the buffer</p>                                                                                                                                                            |

| Offset: 0x0208 |            |             | Register Name: AC_ADC_DRC_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6              | R/W        | 0x0         | ADC_DRC_GAIN_MAX_LIMIT_EN<br>DRC gain max limit enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                                                 |
| 5              | R/W        | 0x0         | ADC_DRC_GAIN_MIN_LIMIT_EN<br>DRC gain min limit enable<br>When this fuction is enabled, it will overwrite the noise detect function.<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                   |
| 4              | R/W        | 0x0         | ADC_DRC_DETECT_NOISE_EN<br>Control the DRC to detect noise when ET is enabled<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                                                          |
| 3              | R/W        | 0x0         | ADC_DRC_SIGNAL_FUNC_SEL<br>Signal function select<br>0: RMS filter<br>1: Peak filter<br>When the signal function selects the Peak filter, the RMS parameter is unused. (AC_DRC_LRMASHAT, AC_DRC_LRMSLAT, AC_DRC_LRMASHAT, and AC_DRC_LRMSLAT)<br>When the signal function selects the RMS filter, the Peak filter parameter is unused. (AC_DRC_LPFHAT, AC_DRC_LPFLAT, AC_DRC_RPFHAT, AC_DRC_RPFLAT, AC_DRC_LPFHRT, AC_DRC_LPFLRT, AC_DRC_RPFHRT, and AC_DRC_RPFLRT) |
| 2              | R/W        | 0x0         | ADC_DRC_DELAY_FUNC_EN<br>Delay function enable<br>0: Disabled<br>1: Enabled<br>When the bit is disabled, the signal delay time is unused.                                                                                                                                                                                                                                                                                                                           |
| 1              | R/W        | 0x0         | ADC_DRC_LT_EN<br>DRC LT enable<br>0: Disabled<br>1: Enabled<br>When the bit is disabled, KI and OPL parameter is unused.                                                                                                                                                                                                                                                                                                                                            |

| Offset: 0x0208 |            |             | Register Name: AC_ADC_DRC_CTRL                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 0              | R/W        | 0x0         | ADC_DRC_ET_EN<br>DRC ET enable<br>0: Disabled<br>1: Enabled<br>When the bit is disabled, Ke and OPE parameter is unused. |

#### 8.4.6.68 0x020C ADC DRC Left Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x020C |            |             | Register Name: AC_ADC_DRC_LPFHAT                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:11          | /          | /           | /                                                                                                                                                                                           |
| 10:0           | R/W        | 0x000B      | ADC_DRC_LPFHAT<br>The left peak filter attack time parameter setting, which is determined by the equation that $AT = 1 - \exp(-2.2Ts/ta)$ . The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.69 0x0210 ADC DRC Left Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0210 |            |             | Register Name: AC_ADC_DRC_LPFLAT                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                           |
| 15:0           | R/W        | 0x77BF      | ADC_DRC_LPFLAT<br>The left peak filter attack time parameter setting, which is determined by the equation that $AT = 1 - \exp(-2.2Ts/ta)$ . The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.70 0x0214 ADC DRC Right Peak Filter High Attack Time Coef Register (Default Value: 0x0000\_000B)

| Offset: 0x0214 |            |             | Register Name: AC_ADC_DRC_RPFHAT |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:16          | /          | /           | /                                |

| Offset: 0x0214 |            |             | Register Name: AC_ADC_DRC_RPFHAT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 15:0           | R/W        | 0x000B      | ADC_DRC_RPFHAT<br>The right peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.71 0x0218 ADC DRC Right Peak Filter Low Attack Time Coef Register (Default Value: 0x0000\_77BF)

| Offset: 0x0218 |            |             | Register Name: AC_ADC_DRC_RPFLAT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                                                       |
| 15:0           | R/W        | 0x77BF      | ADC_DRC_RPFLAT<br>The right peak filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/ta). The format is 3.24. (The default value is 1 ms) |

#### 8.4.6.72 0x021C ADC DRC Left Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x021C |            |             | Register Name: AC_ADC_DRC_LPFHRT                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31:11          | /          | /           | /                                                                                                                                                                                       |
| 10:0           | R/W        | 0x00FF      | ADC_DRC_LPFHRT<br>The left peak filter release time parameter setting, which is determined by the equation that RT = exp (-2.2Ts/tr). The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.73 0x0220 ADC DRC Left Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0220 |            |             | Register Name: AC_ADC_DRC_LPFLRT |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
| 31:16          | /          | /           | /                                |

| Offset: 0x0220 |            |             | Register Name: AC_ADC_DRC_LPFLRT                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 15:0           | R/W        | 0xE1F8      | ADC_DRC_LPFLRT<br>The left peak filter release time parameter setting, which is determined by the equation that $RT = \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.74 0x0224 ADC DRC Right Peak Filter High Release Time Coef Register (Default Value: 0x0000\_00FF)

| Offset: 0x0224 |            |             | Register Name: AC_ADC_DRC_RPFHRT                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                           |
| 15:0           | R/W        | 0x00FF      | ADC_DRC_RPFHRT<br>The right peak filter release time parameter setting, which is determined by the equation that $RT = \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.75 0x0228 ADC DRC Right Peak Filter Low Release Time Coef Register (Default Value: 0x0000\_E1F8)

| Offset: 0x0228 |            |             | Register Name: AC_ADC_DRC_RPFLRT                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                           |
| 15:0           | R/W        | 0xE1F8      | ADC_DRC_RPFLRT<br>The right peak filter release time parameter setting, which is determined by the equation that $RT = \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 100 ms) |

#### 8.4.6.76 0x022C ADC DRC Left RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x022C |            |             | Register Name: AC_ADC_DRC_LRMSHAT |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:11          | /          | /           | /                                 |

| Offset: 0x022C |            |             | Register Name: AC_ADC_DRC_LRMOSHAT                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 10:0           | R/W        | 0x0001      | ADC_DRC_LRMOSHAT<br>The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tav). The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.77 0x0230 ADC DRC Left RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

| Offset: 0x0230 |            |             | Register Name: AC_ADC_DRC_LRMSLAT                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                                                                         |
| 15:0           | R/W        | 0x2BAF      | ADC_DRC_LRMSLAT<br>The left RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tav). The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.78 0x0234 ADC DRC Right RMS Filter High Coef Register (Default Value: 0x0000\_0001)

| Offset: 0x0234 |            |             | Register Name: AC_ADC_DRC_RRMSHAT                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31:11          | /          | /           | /                                                                                                                                                                                          |
| 10:0           | R/W        | 0x0001      | ADC_DRC_RRMSHAT<br>The right RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tav). The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.79 0x0238 ADC DRC Right RMS Filter Low Coef Register (Default Value: 0x0000\_2BAF)

| Offset: 0x0238 |            |             | Register Name: AC_ADC_DRC_RRMSLAT |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:16          | /          | /           | /                                 |

| Offset: 0x0238 |            |             | Register Name: AC_ADC_DRC_RRMSLAT                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 15:0           | R/W        | 0x2BAF      | ADC_DRC_RRMSLAT<br>The right RMS filter average time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tav). The format is 3.24. (The default value is 10 ms) |

#### 8.4.6.80 0x023C ADC DRC Compressor Threshold High Setting Register (Default Value: 0x0000\_06A4)

| Offset: 0x023C |            |             | Register Name: AC_ADC_DRC_HCT                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                       |
| 15:0           | R/W        | 0x06A4      | ADC_DRC_HCT<br>The compressor threshold setting, which is set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.81 0x0240 ADC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_D3C0)

| Offset: 0x0240 |            |             | Register Name: AC_ADC_DRC_LCT                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                                       |
| 15:0           | R/W        | 0xD3C0      | ADC_DRC_LCT<br>The compressor threshold setting, which is set by the equation that CTin = -CT/6.0206. The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.82 0x0244 ADC DRC Compressor Slope High Setting Register (Default Value: 0x0000\_0080)

| Offset: 0x0244 |            |             | Register Name: AC_ADC_DRC_HKC |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x0244 |            |             | Register Name: AC_ADC_DRC_HKC                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 15:0           | R/W        | 0x0080      | ADC_DRC_HKC<br>The slope of the compressor which is determined by the equation that $K_c = 1/R$ . R is the ratio of the compressor, which is always an integer. The format is 8.24. (The default value is <2:1>) |

#### 8.4.6.83 0x0248 ADC DRC Compressor Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0248 |            |             | Register Name: AC_ADC_DRC_LKC                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                                 |
| 15:0           | R/W        | 0x0000      | ADC_DRC_LKC<br>The slope of the compressor, which is determined by the equation that $K_c = 1/R$ . R is the ratio of the compressor, which is always an integer. The format is 8.24. (The default value is <2:1>) |

#### 8.4.6.84 0x024C ADC DRC Compressor High Output at Compressor Threshold Register (Default Value: 0x0000\_F95B)

| Offset: 0x024C |            |             | Register Name: AC_ADC_DRC_HOPC                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                   |
| 15:0           | R/W        | 0xF95B      | ADC_DRC_HOPC<br>The output of the compressor, which is determined by the equation $-OPC/6.0206$ . The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.85 0x0250 ADC DRC Compressor Low Output at Compressor Threshold Register (Default Value: 0x0000\_2C3F)

| Offset: 0x0250 |            |             | Register Name: AC_ADC_DRC_LOPC |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:16          | /          | /           | /                              |

| Offset: 0x0250 |            |             | Register Name: AC_ADC_DRC_LOPC                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
| 15:0           | R/W        | 0x2C3F      | ADC_DRC_LOPC<br>The output of the compressor, which is determined by the equation OPC/6.0206. The format is 8.24. (The default value is -40 dB) |

#### 8.4.6.86 0x0254 ADC DRC Limiter Threshold High Setting Register (Default Value: 0x0000\_01A9)

| Offset: 0x0254 |            |             | Register Name: AC_ADC_DRC_HLT                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                    |
| 15:0           | R/W        | 0x01A9      | ADC_DRC_HLT<br>The limiter threshold setting, which is set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10 dB) |

#### 8.4.6.87 0x0258 ADC DRC Limiter Threshold Low Setting Register (Default Value: 0x0000\_34F0)

| Offset: 0x0258 |            |             | Register Name: AC_ADC_DRC_LLT                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                    |
| 15:0           | R/W        | 0x34F0      | ADC_DRC_LLT<br>The limiter threshold setting, which is set by the equation that LTin = -LT/6.0206. The format is 8.24. (The default value is -10 dB) |

#### 8.4.6.88 0x025C ADC DRC Limiter Slope High Setting Register (Default Value: 0x0000\_0005)

| Offset: 0x025C |            |             | Register Name: AC_ADC_DRC_HKI                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:14          | /          | /           | /                                                                                                                                                                                                        |
| 13:0           | R/W        | 0x0005      | ADC_DRC_HKI<br>The slope of the limiter, which is determined by the equation that KI = 1/R. R is the ratio of the limiter, which is always an integer. The format is 8.24. (The default value is <50:1>) |

**8.4.6.89 0x0260 ADC DRC Limiter Slope Low Setting Register (Default Value: 0x0000\_1EB8)**

| Offset: 0x0260 |            |             | Register Name: AC_ADC_DRC_LKI                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                           |
| 15:0           | R/W        | 0x1EB8      | ADC_DRC_LKI<br>The slope of the limiter, which is determined by the equation that $KI = 1/R$ . R is the ratio of the limiter, which is always an integer. The format is 8.24. (The default value is <50:1>) |

**8.4.6.90 0x0264 ADC DRC Limiter High Output at Limiter Threshold Register (Default Value: 0x0000\_FBD8)**

| Offset: 0x0264 |            |             | Register Name: AC_ADC_DRC_HOPL                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                        |
| 15:0           | R/W        | 0xFBD8      | ADC_DRC_HOPL<br>The output of the limiter, which is determined by equation OPT/6.0206. The format is 8.24. (The default value is -25 dB) |

**8.4.6.91 0x0268 ADC DRC Limiter Low Output at Limiter Threshold Register (Default Value: 0x0000\_FBA7)**

| Offset: 0x0268 |            |             | Register Name: AC_ADC_DRC_LOPL                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:16          | /          | /           | /                                                                                                                                       |
| 15:0           | R/W        | 0xFBA7      | ADC_DRC_LOPL<br>The output of the limiter which is determined by equation OPT/6.0206. The format is 8.24. (The default value is -25 dB) |

**8.4.6.92 0x026C ADC DRC Expander Threshold High Setting Register (Default Value: 0x0000\_0BA0)**

| Offset: 0x026C |            |             | Register Name: AC_ADC_DRC_HET |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x026C |            |             | Register Name: AC_ADC_DRC_HET                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 15:0           | R/W        | 0x0BA0      | ADC_DRC_HET<br>The expander threshold setting, which is set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70 dB) |

#### 8.4.6.93 0x0270 ADC DRC Expander Threshold Low Setting Register (Default Value: 0x0000\_7291)

| Offset: 0x0270 |            |             | Register Name: AC_ADC_DRC_LET                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                     |
| 15:0           | R/W        | 0x7291      | ADC_DRC_LET<br>The expander threshold setting, which is set by the equation that ETin = -ET/6.0206, The format is 8.24. (The default value is -70 dB) |

#### 8.4.6.94 0x0274 ADC DRC Expander Slope High Setting Register (Default Value: 0x0000\_0500)

| Offset: 0x0274 |            |             | Register Name: AC_ADC_DRC_HKE                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                              |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                        |
| 15:0           | R/W        | 0x0500      | ADC_DRC_HKE<br>The slope of the expander, which is determined by the equation that Ke = 1/R. R is the ratio of the expander, which is always an integer and the ke must larger than 50. The format is 8.24. (The default value is <1:5>) |

#### 8.4.6.95 0x0278 ADC DRC Expander Slope Low Setting Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: AC_ADC_DRC_LKE |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:16          | /          | /           | /                             |

| Offset: 0x0278 |            |             | Register Name: AC_ADC_DRC_LKE                                                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                               |
| 15:0           | R/W        | 0x0000      | <p>ADC_DRC_LKE</p> <p>The slope of the expander, which is determined by the equation that <math>Ke = 1/R</math>. R is the ratio of the expander, which is always an integer and the ke must be larger than 50. The format is 8.24. (The default value is &lt;1:5&gt;)</p> |

#### 8.4.6.96 0x027C ADC DRC Expander High Output at Expander Threshold Register (Default Value: 0x0000\_F45F)

| Offset: 0x027C |            |             | Register Name: AC_ADC_DRC_HOPE                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0xF45F      | <p>ADC_DRC_HOPE</p> <p>The output of the expander, which is determined by equation <math>OPE/6.0206</math>. The format is 8.24. (The default value is -70 dB)</p> |

#### 8.4.6.97 0x0280 ADC DRC Expander Low Output at Expander Threshold Register (Default Value: 0x0000\_8D6E)

| Offset: 0x0280 |            |             | Register Name: AC_ADC_DRC_LOPE                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                 |
| 15:0           | R/W        | 0x8D6E      | <p>ADC_DRC_LOPE</p> <p>The output of the expander, which is determined by equation <math>OPE/6.0206</math>. The format is 8.24. (The default value is -70 dB)</p> |

#### 8.4.6.98 0x0284 ADC DRC Linear Slope High Setting Register (Default Value: 0x0000\_0100)

| Offset: 0x0284 |            |             | Register Name: AC_ADC_DRC_HKN                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                   |
| 15:0           | R/W        | 0x0100      | <p>ADC_DRC_HKN</p> <p>The slope of the linear, which is determined by the equation that <math>Kn = 1/R</math>. R is the ratio of the linear, which is always an integer. The format is 8.24. (The default value is &lt;1:1&gt;)</p> |

**8.4.6.99 0x0288 ADC DRC Linear Slope Low Setting Register (Default Value: 0x0000\_0000)**

| Offset: 0x0288 |            |             | Register Name: AC_ADC_DRC_LKN                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                                                                     |
| 15:0           | R/W        | 0x0000      | ADC_DRC_LKN<br>The slope of the linear, which is determined by the equation that Kn = 1/R. R is the ratio of the linear, which is always an integer. The format is 8.24. (The default value is <1:1>) |

**8.4.6.100 0x028C ADC DRC Smooth Filter Gain High Attack Time Coef Register (Default Value: 0x0000\_0002)**

| Offset: 0x028C |            |             | Register Name: AC_ADC_DRC_SFHAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:11          | /          | /           | /                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0002      | ADC_DRC_SFHAT<br>The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 5 ms) |

**8.4.6.101 0x0290 ADC DRC Smooth Filter Gain Low Attack Time Coef Register (Default Value: 0x0000\_5600)**

| Offset: 0x0290 |            |             | Register Name: AC_ADC_DRC_SFLAT                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16          | /          | /           | /                                                                                                                                                                                  |
| 15:0           | R/W        | 0x5600      | ADC_DRC_SFLAT<br>The smooth filter attack time parameter setting, which is determined by the equation that AT = 1-exp (-2.2Ts/tr). The format is 3.24. (The default value is 5 ms) |

#### 8.4.6.102 0x0294 ADC DRC Smooth Filter Gain High Release Time Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x0294 |            |             | Register Name: AC_ADC_DRC_SFHRT                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:11          | /          | /           | /                                                                                                                                                                                               |
| 10:0           | R/W        | 0x0000      | ADC_DRC_SFHRT<br>The gain smooth filter release time parameter setting, which is determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 200 ms) |

#### 8.4.6.103 0x0298 ADC DRC Smooth Filter Gain Low Release Time Coef Register (Default Value: 0x0000\_0F04)

| Offset: 0x0298 |            |             | Register Name: AC_ADC_DRC_SFLRT                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:16          | /          | /           | /                                                                                                                                                                                               |
| 15:0           | R/W        | 0x0F04      | ADC_DRC_SFLRT<br>The gain smooth filter release time parameter setting, which is determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 200 ms) |

#### 8.4.6.104 0x029C ADC DRC MAX Gain High Setting Register (Default Value: 0x0000\_FE56)

| Offset: 0x029C |            |             | Register Name: AC_ADC_DRC_MXGHS                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:16          | /          | /           | /                                                                                                                                                                                                   |
| 15:0           | R/W        | 0xFE56      | ADC_DRC_MXGHS<br>The max gain setting, which is determined by equation $MXG_{in} = MXG / 6.0206$ . The format is 8.24 and must $-20 \text{ dB} < MXG < 30 \text{ dB}$ (The default value is -10 dB) |

#### 8.4.6.105 0x02A0 ADC DRC MAX Gain Low Setting Register (Default Value: 0x0000\_CB0F)

| Offset: 0x02A0 |            |             | Register Name: AC_ADC_DRC_MXGLS |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:16          | /          | /           | /                               |

| Offset: 0x02A0 |            |             | Register Name: AC_ADC_DRC_MXGLS                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 15:0           | R/W        | 0xCBOF      | ADC_DRC_MXGLS<br>The max gain setting, which is determined by equation MXG <sub>in</sub> =MXG/6.0206. The format is 8.24 and must -20 dB < MXG < 30 dB (The default value is -10 dB) |

#### 8.4.6.106 0x02A4 ADC DRC MIN Gain High Setting Register (Default Value: 0x0000\_F95B)

| Offset: 0x02A4 |            |             | Register Name: AC_ADC_DRC_MNGHS                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                                                     |
| 15:0           | R/W        | 0xF95B      | ADC_DRC_MNGHS<br>The min gain setting, which is determined by equation MXG <sub>in</sub> =MXG/6.0206. The format is 8.24 and must -60 dB ≤ MNG ≤ -40 dB (The default value is -40 dB) |

#### 8.4.6.107 0x02A8 ADC DRC MIN Gain Low Setting Register (Default Value: 0x0000\_2C3F)

| Offset: 0x02A8 |            |             | Register Name: AC_ADC_DRC_MNGLS                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                                                     |
| 15:0           | R/W        | 0x2C3F      | ADC_DRC_MNGLS<br>The min gain setting, which is determined by equation MXG <sub>in</sub> =MNG/6.0206. The format is 8.24 and must -60 dB ≤ MNG ≤ -40 dB (The default value is -40 dB) |

#### 8.4.6.108 0x02AC ADC DAP Expander Smooth Time High Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x02AC |            |             | Register Name: AC_ADC_DRC_EPSHC |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:11          | /          | /           | /                               |

| Offset: 0x02AC |            |             | Register Name: AC_ADC_DRC_EPSHC                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 10:0           | R/W        | 0x0000      | ADC_DRC_EPSHC<br>The gain smooth filter release and attack time parameter setting in expander region, which is determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 30 ms) |

#### 8.4.6.109 0x02B0 ADC DRC Expander Smooth Time Low Coef Register (Default Value: 0x0000\_640C)

| Offset: 0x02B0 |            |             | Register Name: AC_ADC_DRC_EPSLC                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                                                                                                            |
| 15:0           | R/W        | 0x640C      | ADC_DRC_EPSLC<br>The gain smooth filter release and attack time parameter setting in expander region, which is determined by the equation that $RT = 1 - \exp(-2.2Ts/tr)$ . The format is 3.24. (The default value is 30 ms) |

#### 8.4.6.110 0x02B8 ADC DRC HPF Gain High Coef Register (Default Value: 0x0000\_0100)

| Offset: 0x02B8 |            |             | Register Name: AC_ADC_DRC_HPFHGAIN                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:11          | /          | /           | /                                                                                         |
| 10:0           | R/W        | 0x100       | ADC_DRC_HPFHGAIN<br>The gain of HPF coefficient setting, which format is 3.24. (gain = 1) |

#### 8.4.6.111 0x02BC ADC DRC HPF Gain Low Coef Register (Default Value: 0x0000\_0000)

| Offset: 0x02BC |            |             | Register Name: AC_ADC_DRC_HPFLGAIN                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:16          | /          | /           | /                                                                                         |
| 15:0           | R/W        | 0x0000      | ADC_DRC_HPFLGAIN<br>The gain of HPF coefficient setting, which format is 3.24. (gain = 1) |

## 8.4.6.112 0x0300 ADC1 Analog Control Register (Default Value: 0x001C\_C055)

| Offset: 0x0300 |            |             | Register Name: ADC1_REG                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 31             | R/W        | 0x0         | ADC1_EN<br>ADC1 Channel Enable<br>0: Disabled<br>1: Enabled                                                                                                      |
| 30             | R/W        | 0x0         | Reserved                                                                                                                                                         |
| 29             | R/W        | 0x0         | ADC1 Dither Control<br>0: New Dither Off<br>1: New Dither On                                                                                                     |
| 28             | R/W        | 0x0         | Reserved                                                                                                                                                         |
| 27             | R/W        | 0x0         | FMINLEN<br>FMINL Enable<br>0: Disable<br>1: Enable                                                                                                               |
| 26             | R/W        | 0x0         | FMINLG<br>FMINL Gain Control<br>0: 0 dB<br>1: 6 dB                                                                                                               |
| 25:24          | R/W        | 0x0         | DSM_DITHER_LVL<br>Dither Level Control (Dither level is positive related to the ctrl bits)<br>00: No Level<br>01: Min Level<br>10: Middle Level<br>11: Max Level |
| 23             | R/W        | 0x0         | LINEINLEN<br>LINEINL Enable<br>0: Disable<br>1: Enable                                                                                                           |
| 22             | R/W        | 0x0         | LINEINLG<br>LINEINL Gain Control<br>0: 0 dB<br>1: 6 dB                                                                                                           |

| Offset: 0x0300 |            |             | Register Name: ADC1_REG                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 21:20          | R/W        | 0x1         | IOPBUFFER<br>PGA Vcm Buffer OP Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                               |
| 19:18          | R/W        | 0x3         | ADC1_PGA_CTRL_RCM<br>ADC1 PGA Common Mode Input Impedance Control for MICIN<br>00: 100 kΩ<br>01: 75 kΩ<br>10: 50 kΩ<br>11: 25 kΩ |
| 17:16          | R/W        | 0x0         | ADC1_PGA_IN_VCM_CTRL<br>ADC1 PGA Common-Mode Voltage Control<br>00: 900 mV<br>01: 800 mV<br>10: 750 mV<br>11: 700 mV             |
| 15:14          | R/W        | 0x3         | IOPADC<br>ADC1-ADC3 Bias Current Select<br>00: 1 uA<br>01: 2 uA<br>10: 3 uA<br>11: 4 uA                                          |
| 13             | /          | /           | /                                                                                                                                |

| Offset: 0x0300 |            |             | Register Name: ADC1_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12:8           | R/W        | 0x0         | <p>ADC1_PGA_GAIN_CTRL<br/>ADC1 PGA gain settings:<br/>0x0: 0 dB 0x10: 21 dB<br/>0x1: 6 dB 0x11: 22 dB<br/>0x2: 6 dB 0x12: 23 dB<br/>0x3: 6 dB 0x13: 24 dB<br/>0x4: 9 dB 0x14: 25 dB<br/>0x5: 10 dB 0x15: 26 dB<br/>0x6: 11 dB 0x16: 27 dB<br/>0x7: 12 dB 0x17: 28 dB<br/>0x8: 13 dB 0x18: 29 dB<br/>0x9: 14 dB 0x19: 30 dB<br/>0xA: 15 dB 0x1A: 31 dB<br/>0xB: 16 dB 0x1B: 32 dB<br/>0xC: 17 dB 0x1C: 33 dB<br/>0xD: 18 dB 0x1D: 34 dB<br/>0xE: 19 dB 0x1E: 35 dB<br/>0xF: 20 dB 0x1F: 36 dB</p> |
| 7:6            | R/W        | 0x1         | <p>ADC1_IOPAAF<br/>ADC1 OP AAF Bias Current Select<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.<br/>For example:<br/>ADC1_REG&lt;15:14&gt; = 11, IOPADC = 4 uA<br/>00: 1.50*4 uA = 6 uA<br/>01: 1.75*4 uA = 7 uA<br/>10: 2.00*4 uA = 8 uA<br/>11: 2.25*4 uA = 9 uA</p>                                                                                                                      |

| Offset: 0x0300 |            |             | Register Name: ADC1_REG                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 5:4            | R/W        | 0x1         | <p>ADC1_IOPSDM1<br/>ADC1 OP SDM Bias Current Select 1<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.</p> |
| 3:2            | R/W        | 0x1         | <p>ADC1_IOPSDM2<br/>ADC1 OP SDM Bias Current Select 2<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.</p> |
| 1:0            | R/W        | 0x1         | <p>ADC1_IOPMIC<br/>ADC1 OP MIC Bias Current Select<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.</p>    |

#### 8.4.6.113 0x0304 ADC2 Analog Control Register (Default Value: 0x001C\_0055)

| Offset: 0x0304 |            |             | Register Name: ADC2_REG                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31             | R/W        | 0x0         | <p>ADC2_EN<br/>ADC2 Channel Enable<br/>0: Disabled<br/>1: Enabled</p> |
| 30             | R/W        | 0x0         | Reserved                                                              |
| 29             | R/W        | 0x0         | <p>ADC2 Dither Control<br/>0: New Dither Off<br/>1: New Dither On</p> |
| 28             | R/W        | 0x0         | Reserved                                                              |

| Offset: 0x0304 |            |             | Register Name: ADC2_REG                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 27             | R/W        | 0x0         | FMINREN<br>FMINR Enable<br>0: Disable<br>1: Enable                                                                                                               |
| 26             | R/W        | 0x0         | FMINRG<br>FMINR Gain Control<br>0: 0 dB<br>1: 6 dB                                                                                                               |
| 25:24          | R/W        | 0x0         | DSM_DITHER_LVL<br>Dither Level Control (Dither level is positive related to the ctrl bits)<br>00: No Level<br>01: Min Level<br>10: Middle Level<br>11: Max Level |
| 23             | R/W        | 0x0         | LINEINREN<br>LINEINR Enable<br>0: Disable<br>1: Enable                                                                                                           |
| 22             | R/W        | 0x0         | LINEINRG<br>LINEINR Gain Control<br>0: 0 dB<br>1: 6 dB                                                                                                           |
| 21:20          | R/W        | 0x1         | IOPBUFFER<br>PGA Vcm Buffer OP Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                                               |
| 19:18          | R/W        | 0x3         | ADC2_PGA_CTRL_RCM<br>ADC2 PGA Common Mode Input Impedance Control for MICIN<br>00: 100 kΩ<br>01: 75 kΩ<br>10: 50 kΩ<br>11: 25 kΩ                                 |

| Offset: 0x0304 |            |             | Register Name: ADC2_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17:16          | R/W        | 0x0         | ADC2_PGA_IN_VCM_CTRL<br>ADC2 PGA Common-Mode Voltage Control<br>00: 900 mV<br>01: 800 mV<br>10: 750 mV<br>11: 700 mV                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 12:8           | R/W        | 0x0         | ADC2_PGA_GAIN_CTRL<br>ADC2 PGA Gain Settings<br>0x0: 0 dB    0x10: 21 dB<br>0x1: 6 dB    0x11: 22 dB<br>0x2: 6 dB    0x12: 23 dB<br>0x3: 6 dB    0x13: 24 dB<br>0x4: 9 dB    0x14: 25 dB<br>0x5: 10 dB    0x15: 26 dB<br>0x6: 11 dB    0x16: 27 dB<br>0x7: 12 dB    0x17: 28 dB<br>0x8: 13 dB    0x18: 29 dB<br>0x9: 14 dB    0x19: 30 dB<br>0xA: 15 dB    0x1A: 31 dB<br>0xB: 16 dB    0x1B: 32 dB<br>0xC: 17 dB    0x1C: 33 dB<br>0xD: 18 dB    0x1D: 34 dB<br>0xE: 19 dB    0x1E: 35 dB<br>0xF: 20 dB    0x1F: 36 dB |
| 7:6            | R/W        | 0x1         | ADC2_IOPAAF<br>ADC2 OP AAF Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA.                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0304 |            |             | Register Name: ADC2_REG                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 5:4            | R/W        | 0x1         | ADC2_IOPSDM1<br>ADC2 OP SDM Bias Current Select 1<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA. |
| 3:2            | R/W        | 0x1         | ADC2_IOPSDM2<br>ADC2 OP SDM Bias Current Select 2<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA. |
| 1:0            | R/W        | 0x1         | ADC2_IOPMIC<br>ADC2 OP MIC Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA.    |

#### 8.4.6.114 0x0308 ADC3 Analog Control Register (Default Value: 0x001C\_0055)

| Offset: 0x0308 |            |             | Register Name: ADC3_REG                                     |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31             | R/W        | 0x0         | ADC3_EN<br>ADC3 Channel Enable<br>0: Disabled<br>1: Enabled |
| 30             | R/W        | 0x0         | MIC3_PGA_EN<br>MIC3 PGA Enable<br>0: Disabled<br>1: Enabled |

| Offset: 0x0308 |            |             | Register Name: ADC3_REG                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                      |
| 29             | R/W        | 0x0         | ADC3 Dither Control<br>0: New Dither Off<br>1: New Dither On                                                                                                     |
| 28             | R/W        | 0x0         | MIC3_SIN_EN<br>MIC3 Single Input Enable<br>0: Disabled<br>1: Enabled                                                                                             |
| 27:26          | /          | /           | /                                                                                                                                                                |
| 25:24          | R/W        | 0x0         | DSM_DITHER_LVL<br>Dither Level Control (Dither level is positive related to the ctrl bits)<br>00: No Level<br>01: Min Level<br>10: Middle Level<br>11: Max Level |
| 23:22          | /          | /           | /                                                                                                                                                                |
| 21:20          | R/W        | 0x1         | IOPBUFFER<br>PGA Vcm Buffer OP Bias Current Select<br>00: 6 $\mu$ A<br>01: 7 $\mu$ A<br>10: 8 $\mu$ A<br>11: 9 $\mu$ A                                           |
| 19:18          | R/W        | 0x3         | ADC3_PGA_CTRL_RCM<br>ADC3 PGA Common Mode Input Impedance Control for MICIN<br>00: 100 k $\Omega$<br>01: 75 k $\Omega$<br>10: 50 k $\Omega$<br>11: 25 k $\Omega$ |
| 17:16          | R/W        | 0x0         | ADC3_PGA_IN_VCM_CTRL<br>ADC3 PGA Common-Mode Voltage Control<br>00: 900 mV<br>01: 800 mV<br>10: 750 mV<br>11: 700 mV                                             |
| 15:13          | /          | /           | /                                                                                                                                                                |

| Offset: 0x0308 |            |             | Register Name: ADC3_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 12:8           | R/W        | 0x0         | ADC3_PGA_GAIN_CTRL<br>ADC3 PGA Gain Settings<br>0x0: 0 dB 0x10: 21 dB<br>0x1: 6 dB 0x11: 22 dB<br>0x2: 6 dB 0x12: 23 dB<br>0x3: 6 dB 0x13: 24 dB<br>0x4: 9 dB 0x14: 25 dB<br>0x5: 10 dB 0x15: 26 dB<br>0x6: 11 dB 0x16: 27 dB<br>0x7: 12 dB 0x17: 28 dB<br>0x8: 13 dB 0x18: 29 dB<br>0x9: 14 dB 0x19: 30 dB<br>0xA: 15 dB 0x1A: 31 dB<br>0xB: 16 dB 0x1B: 32 dB<br>0xC: 17 dB 0x1C: 33 dB<br>0xD: 18 dB 0x1D: 34 dB<br>0xE: 19 dB 0x1E: 35 dB<br>0xF: 20 dB 0x1F: 36 dB |
| 7:6            | R/W        | 0x1         | ADC3_IOPAAF<br>ADC3 OP AAF Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA.                                                                                                                                                                                                                                                                                   |
| 5:4            | R/W        | 0x1         | ADC3_IOPSDM1<br>ADC3 OP SDM Bias Current Select 1<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA.                                                                                                                                                                                                                                                                                |

| Offset: 0x0308 |            |             | Register Name: ADC3_REG                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
| 3:2            | R/W        | 0x1         | <p>ADC3_IOPSDM2<br/>ADC3 OP SDM Bias Current Select 2<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.</p> |
| 1:0            | R/W        | 0x1         | <p>ADC3_IOPMIC<br/>ADC3 OP MIC Bias Current Select<br/>00: 1.50*IOPADC<br/>01: 1.75*IOPADC<br/>10: 2.00*IOPADC<br/>11: 2.25*IOPADC<br/>IOPADC is defined by ADC1_REG&lt;15:14&gt; from 1 uA to 4 uA.</p>    |

#### 8.4.6.115 0x0310 DAC Analog Control Register (Default Value: 0x0015\_0000)

| Offset: 0x0310 |            |             | Register Name: DAC_REG                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:24          | /          | /           | /                                                                                                                                         |
| 23             | R/W        | 0x0         | <p>CURRENT_TEST_SELECT<br/>Internal Current Sink Test Enable (from MICIN3P pin)<br/>0: Normal<br/>1: For Debug</p>                        |
| 22             | /          | /           | /                                                                                                                                         |
| 21:20          | R/W        | 0x1         | <p>IOPVRS<br/>VRA2 Buffer OP and Headphone Feedback Buffer OP Bias Current Select<br/>00: 6 uA<br/>01: 7 uA<br/>10: 8 uA<br/>11: 9 uA</p> |
| 19:18          | R/W        | 0x1         | Reserved                                                                                                                                  |

| Offset: 0x0310 |            |             | Register Name: DAC_REG                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 17:16          | R/W        | 0x1         | IOPDACS<br>OPDACL/R Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA |
| 15             | R/W        | 0x0         | DACL_EN<br>DACL Enable<br>0: Disabled<br>1: Enabled                                     |
| 14             | R/W        | 0x0         | DACR_EN<br>DACR Enable<br>0: Disabled<br>1: Enabled                                     |
| 13             | R/W        | 0x0         | Reserved                                                                                |
| 12             | R/W        | 0x0         | Reserved                                                                                |
| 11             | R/W        | 0x0         | Reserved                                                                                |
| 10             | R/W        | 0x0         | Reserved                                                                                |
| 9:7            | /          | /           | /                                                                                       |
| 6              | R/W        | 0x0         | Reserved                                                                                |
| 5              | R/W        | 0x0         | Reserved                                                                                |
| 4:0            | R/W        | 0x0         | Reserved                                                                                |

#### 8.4.6.116 0x0318 MICBIAS Analog Control Register (Default Value: 0x4000\_3030)

| Offset: 0x0318 |            |             | Register Name: MICBIAS_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31             | /          | /           | /                          |

| Offset: 0x0318 |            |             | Register Name: MICBIAS_REG                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 30:28          | R/W        | 0x4         | <p>SELDETADCFS<br/>Select sample interval of the ADC sample</p> <p>000: 2 ms<br/>...<br/>100: 32 ms<br/>...<br/>111: 256 ms</p>                  |
| 27:26          | R/W        | 0x0         | <p>SELDETADCDB<br/>Select debounce time when jack removal</p> <p>00: 128 ms<br/>01: 256 ms<br/>10: 512 ms<br/>11: 1024 ms</p>                    |
| 25:24          | R/W        | 0x0         | <p>SELDETADCBF<br/>Select the time to enable HBIAS before MICADC work</p> <p>00: 2 ms<br/>01: 4 ms<br/>10: 8 ms<br/>11: 16 ms</p>                |
| 23             | R/W        | 0x0         | <p>JACKDETEN<br/>Jack detect enable</p> <p>0: Disable<br/>1: Enable</p>                                                                          |
| 22:21          | R/W        | 0x0         | <p>SELDETADCDY<br/>Select the delay time to pull low the micdet when jack removal</p> <p>00: 0.5 ms<br/>01: 1 ms<br/>10: 1.5 ms<br/>11: 2 ms</p> |
| 20             | R/W        | 0x0         | <p>MICADCEN<br/>Microphone detect ADC enable</p> <p>0: Disabled<br/>1: Enabled</p>                                                               |
| 19             | R/W        | 0x0         | <p>POPFREE<br/>When this bit is 0, HBIAS MICADC is controlled by register</p>                                                                    |

| Offset: 0x0318 |            |             | Register Name: MICBIAS_REG                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                    |
| 18             | R/W        | 0x0         | <p>DET_MODE</p> <p>MIC Detect Mode</p> <p>0: Jack in pull low</p> <p>1: Jack in pull high</p>                                                  |
| 17             | R/W        | 0x0         | <p>AUTOPEN</p> <p>Enable the function to auto pull low MICDET when jack removal</p> <p>0: Disabled</p> <p>1: Enabled</p>                       |
| 16             | R/W        | 0x0         | <p>MICDETPL</p> <p>When this bit is 1 and AUTOPEN is 0, the MICDET is pulled down to GND.</p>                                                  |
| 15             | R/W        | 0x0         | <p>HMICBIASEN</p> <p>Headphone Microphone Bias Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                 |
| 14:13          | R/W        | 0x1         | <p>HBIASSEL</p> <p>HMICBIAS Voltage Level Select</p> <p>00: 1.88 V</p> <p>01: 2.09 V</p> <p>10: 2.33 V</p> <p>11: 2.55 V</p>                   |
| 12             | R/W        | 0x1         | <p>HMIC_BIAS_CHOPPER_EN</p> <p>HMIC BIAS Chopper Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                               |
| 11:10          | R/W        | 0x0         | <p>HMIC_BIAS_CHOPPER_CLK_SEL</p> <p>HMIC BIAS Chopper Clock Select</p> <p>00: 250 kHz</p> <p>01: 500 kHz</p> <p>10: 1 MHz</p> <p>11: 2 MHz</p> |
| 9:8            | /          | /           | /                                                                                                                                              |
| 7              | R/W        | 0x0         | <p>MMICBIASEN</p> <p>Master Microphone Bias Enable</p> <p>0: Disabled</p> <p>1: Enabled</p>                                                    |

| Offset: 0x0318 |            |             | Register Name: MICBIAS_REG                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                     |
| 6:5            | R/W        | 0x1         | <p>MBIASSEL<br/>MMICBIAS Voltage Level Select<br/>00: 1.88 V<br/>01: 2.09 V<br/>10: 2.33 V<br/>11: 2.50 V</p>                   |
| 4              | R/W        | 0x1         | <p>MMIC_BIAS_CHOPPER_EN<br/>MMIC BIAS Chopper Enable<br/>0: Disabled<br/>1: Enabled</p>                                         |
| 3:2            | R/W        | 0x0         | <p>MMIC_BIAS_CHOPPER_CLK_SEL<br/>MMIC BIAS Chopper Clock Select<br/>00: 250 kHz<br/>01: 500 kHz<br/>10: 1 MHz<br/>11: 2 MHz</p> |
| 1:0            | /          | /           | /                                                                                                                               |

#### 8.4.6.117 0x031C Ramp Control Register (Default Value: 0x0018\_0000)

| Offset: 0x031C |            |             | Register Name: RAMP_REG                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
| 31             | R/W        | 0x0         | <p>RAMP_RISE_INT_EN<br/>RAMP Rise Interrupt Enable<br/>0: Enabled<br/>1: Disabled</p>                                                                                                      |
| 30             | R/W1C      | 0x0         | <p>RAMP_RISE_INT<br/>RK Increase Upward Finish and Rampen Pull Down Instruction<br/>0: No Pending IRQ<br/>1: Ramp Rise Finish Pending Interrupt<br/>Write '1' to clear this interrupt.</p> |
| 29             | R/W        | 0x0         | <p>RAMP_FALL_INT_EN<br/>RAMP Fall Int Enable<br/>0: Enabled<br/>1: Disabled</p>                                                                                                            |

| Offset: 0x031C |            |             | Register Name: RAMP_REG                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 28             | R/W1C      | 0x0         | <p>RAMP_FALL_INT<br/>RK Downward Decrease Finish and Rampen Pull Down Instruction<br/>0: No Pending IRQ<br/>1: Ramp Fall Finish Pending Interrupt<br/>Write '1' to clear this interrupt.</p> |
| 27:25          | /          | /           | /                                                                                                                                                                                            |
| 24             | R/W        | 0x0         | <p>RAMP_SRST<br/>Ramp Soft Reset<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                          |
| 23:21          | /          | /           | /                                                                                                                                                                                            |
| 20:16          | R/W        | 0x18        | <p>RAMP_CLK_DIV_M<br/>Analog Ramp Clk Div Freq Value : M (from 0 to 31, Default: 24).<br/>Ana_Ramp_Clk= 24MHz/(M+1)<br/>Default Ramp Clk Freq: 24MHz/(24+1)=960 kHz</p>                      |
| 15             | R/W        | 0x0         | <p>HP_PULL_OUT_EN<br/>Headphone Pullout Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                            |

| Offset: 0x031C |            |             | Register Name: RAMP_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14:12          | R/W        | 0x0         | <p>RAMP_HOLD_STEP<br/>RAMP HOLD STEP<br/>000: 9600<br/>001: 19200<br/>010: 38400<br/>011: 76800<br/>100: 96000<br/>101: 115200<br/>110: 153600<br/>111: 192000</p> <p>Ramp Hold Time = Ramp Hold Step/Ramp Clk Freq<br/>When Ramp Clk Freq is equal to 960 kHz, the corresponding Ramp Hold time of each gear is:</p> <p>000: 9600/960 kHz=10 ms<br/>001: 19200/960 kHz=20 ms<br/>010: 38400/960 kHz=40 ms<br/>011: 76800/960 kHz=80 ms<br/>100: 96000/960 kHz=100 ms<br/>101: 115200/960 kHz=120 ms<br/>110: 153600/960 kHz=160 ms<br/>111: 192000/960 kHz=200 ms</p> |
| 11:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9:8            | R/W        | 0x0         | <p>GAP_STEP<br/>Gap Step<br/>00: ramp step<br/>01: ramp step*2<br/>10: ramp step*3<br/>11: ramp step*4</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x031C |            |             | Register Name: RAMP_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6:4            | R/W        | 0x0         | <p>RAMP_STEP<br/>RK Frequency Gear, Control Ramp Rise/Fall Total Time<br/>000: 20<br/>001: 30<br/>010: 40<br/>011: 60<br/>100: 80<br/>101: 120<br/>110: 160<br/>111: 240</p> <p>Ramp Rise/Fall Total Time =(Ramp Step/Ramp Clk Freq)*4096<br/>When Default Ramp Clk Freq is equal to 960 kHz, the corresponding time of each gear is:</p> <p>000: <math>(20/960\text{kHz})*4096=85.3\text{ ms}</math><br/>001: <math>(30/960\text{kHz})*4096=128\text{ ms}</math><br/>010: <math>(40/960\text{kHz})*4096=170.6\text{ ms}</math><br/>011: <math>(60/960\text{kHz})*4096=256\text{ ms}</math><br/>100: <math>(80/960\text{kHz})*4096=341.3\text{ ms}</math><br/>101: <math>(120/960\text{kHz})*4096=512\text{ ms}</math><br/>110: <math>(160/960\text{kHz})*4096=682.6\text{ ms}</math><br/>111: <math>(240/960\text{kHz})*4096=1024\text{ ms}</math></p> |
| 3              | R/W        | 0x0         | <p>RMD_EN<br/>Ramp Manual Down Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2              | R/W        | 0x0         | <p>RMU_EN<br/>Ramp Manual Up Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1              | R/W        | 0x0         | <p>RMC_EN<br/>Ramp Manual Control Enable<br/>0: Disabled<br/>1: Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Offset: 0x031C |            |             | Register Name: RAMP_REG                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 0              | R/W        | 0x0         | <p>RD_EN</p> <p>Ramp Digital Enable</p> <p>0: Disabled</p> <p>1: Enabled</p> |

#### 8.4.6.118 0x0320 BIAS Analog Control Register (Default Value: 0x0000\_0080)

The register is not controlled by the clock and reset of Audio Codec, only controlled by the clock and reset of system bus.

| Offset: 0x0320 |            |             | Register Name: BIAS_REG                                   |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:8           | /          | /           | /                                                         |
| 7:0            | R/W        | 0x80        | <p>BIASDATA</p> <p>Bias Current Register Setting Data</p> |

#### 8.4.6.119 0x0328 HMIC Control Register (Default Value: 0x0000\_0008)

| Offset: 0x0328 |            |             | Register Name: HMIC_CTRL                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:23          | /          | /           | /                                                                                                                                                                            |
| 22:21          | R/W        | 0x0         | <p>HMIC_SAMPLE_SELECT</p> <p>Down Sample Setting Select</p> <p>00: Down by 1, 128 Hz</p> <p>01: Down by 2, 64 Hz</p> <p>10: Down by 4, 32 Hz</p> <p>11: Down by 8, 16 Hz</p> |
| 20:16          | R/W        | 0x0         | <p>MDATA_THRESHOLD</p> <p>MIC DET EN Threshold Value</p>                                                                                                                     |

| Offset: 0x0328 |            |             | Register Name: HMIC_CTRL                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                          |
| 15:14          | R/W        | 0x0         | HMIC_SF<br>HMIC Smooth Filter setting<br>00: by pass<br>01: (x1+x2)/2<br>10: (x1+x2+x3+x4)/4<br>11: (x1+x2+x3+x4+ x5+x6+x7+x8)/8     |
| 13:10          | R/W        | 0x0         | HMIC_M<br>Debounce when the MIC Key down or up.<br>0000 :1 samlpe data<br>0001 :2 samlpe data<br>...<br>1111:16 samlpe data          |
| 9:6            | R/W        | 0x0         | HMIC_N<br>Debounce when earphone plug in or pull out<br>125 ms to 2 s<br>0000:125 ms<br>0001:250 ms<br>...<br>1111:2 s               |
| 5:3            | R/W        | 0x1         | MDATA_THRESHOLD_DEBOUNCE<br>MDATA Threshold Debounce<br>000: 0<br>001: 1<br>010: 2<br>011: 3<br>100: 4<br>101: 5<br>110: 6<br>111: 7 |
| 2              | R/W        | 0x0         | JACK_OUT_IRQ_EN<br>MIC Detect Interrupt Set<br>0: Disabled<br>1: Enabled                                                             |

| Offset: 0x0328 |            |             | Register Name: HMIC_CTRL                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 1              | R/W        | 0x0         | JACK_IN_IRQ_EN<br>MIC Detect Interrupt Set<br>0: Disabled<br>1: Enabled |
| 0              | R/W        | 0x0         | MIC_DET_IRQ_EN<br>MIC Detect Interrupt Set<br>0: Disabled<br>1: Enabled |

#### 8.4.6.120 0x032C HMIC Status Register (Default Value: 0x0000\_6000)

| Offset: 0x032C |            |             | Register Name: HMIC_STS                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 31:15          | /          | /           | /                                                                                                                                                                                                            |
| 14:13          | R/W        | 0x3         | MDATA_DISCARD<br>After MIC DATA data is received, the first N-data will be discarded.<br>N defined as follows:<br>00: None discarded<br>01: 1-data discarded<br>10: 2-data discarded<br>11: 4-data discarded |
| 12:8           | R          | 0x0         | HMIC_DATA<br>HMIC Average Data                                                                                                                                                                               |
| 7:5            | /          | /           |                                                                                                                                                                                                              |
| 4              | R/W1C      | 0x0         | JACK_DET_OIRQ<br>Jack output detect pending interrupt<br>0: No Pending IRQ<br>1: Pending IRQ<br>Writing 1 clear pending.                                                                                     |
| 3              | R/W1C      | 0x0         | JACK_DET_IIRQ<br>Jack input detect pending interrupt<br>0: No Pending IRQ<br>1: Pending IRQ<br>Writing 1 clear pending.                                                                                      |
| 2:1            | /          | /           | /                                                                                                                                                                                                            |

| Offset: 0x032C |            |             | Register Name: HMIC_STS                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 0              | R/W1C      | 0x0         | <p>MIC_DET_ST<br/>MIC detect pending interrupt<br/>0: No pending IRQ<br/>1: Pending IRQ<br/>Writing 1 clear pending.</p> |

#### 8.4.6.121 0x0340 Headphone2 Analog Control Register (Default Value: 0x0640\_4000)

| Offset: 0x0340 |            |             | Register Name: HP2_REG                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 31             | R/W        | 0x0         | <p>HPFB_BUF_EN<br/>Headphone Feedback Buffer OP Enable<br/>0: Disable<br/>1: Enable</p>                                                                               |
| 30:28          | R/W        | 0x0         | <p>HEADPHONE_GAIN<br/>HeadPhone Gain<br/>000: 0 dB<br/>001: -6 dB<br/>010: -12 dB<br/>011: -18 dB<br/>100: -24 dB<br/>101: -30 dB<br/>110: -36 dB<br/>111: -42 dB</p> |
| 27:26          | R/W        | 0x1         | <p>HPFB_RES<br/>Headphone Feedback Big Resistor Control<br/>00: 0.88 MΩ<br/>01: 1.00 MΩ<br/>10: 1.08 MΩ<br/>11: 1.20 MΩ</p>                                           |
| 25:24          | R/W        | 0x2         | <p>OPDRV_CUR<br/>Headphone OP Output Stage Current Setting<br/>00: Min<br/>11: Max</p>                                                                                |

| Offset: 0x0340 |            |             | Register Name: HP2_REG                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 23:22          | R/W        | 0x1         | IOPHP<br>Headphone L/R OP Bias Current Select<br>00: 6 uA<br>01: 7 uA<br>10: 8 uA<br>11: 9 uA                                     |
| 21             | R/W        | 0x0         | HP_DRVEN<br>Headphone Driver Enable<br>0: Disable<br>1: Enable                                                                    |
| 20             | R/W        | 0x0         | HP_DRVOUTEN<br>Headphone Driver Output Enable<br>0: Disabled<br>1: Enabled                                                        |
| 19             | R/W        | 0x0         | RSWITCH<br>RSwitch<br>0: HPOUT OUTPUT VCM of RAMP_DAC<br>1: VRA1                                                                  |
| 18             | R/W        | 0x0         | RAMPEN<br>Ramp DAC Enable<br>0: Disabled<br>1: Enabled                                                                            |
| 17             | R/W        | 0x0         | HPFB_IN_EN<br>Headphone Feedback PAD IN Switch Enable<br>0: Disabled<br>1: Enabled                                                |
| 16             | R/W        | 0x0         | RAMP_FINAL_CONTROL<br>Headphone Ramp Final Step Control<br>0: Ramp Output Select Ramp<br>1: Ramp Output Select HPFB buffer Output |
| 15             | R/W        | 0x0         | RAMP_OUT_EN<br>Ramp Output Switch Enable<br>0: Disable<br>1: Enable                                                               |

| Offset: 0x0340 |            |             | Register Name: HP2_REG                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 14:13          | R/W        | 0x2         | RAMP_FINAL_STATE_RES<br>Ramp Final State Resistor<br>00: 2.5k<br>01: 5.0k<br>10: 10k<br>11: 20k                                  |
| 9:8            | R/W        | 0x0         | HPFB_BUF_OUTPUT_CURRENT<br>Headphone Feedback Buffer Output Current Select<br>00: 35I<br>01: 28I<br>10: 45I<br>11: 38I<br>I=7 uA |
| 7:0            | /          | /           | /                                                                                                                                |

#### 8.4.6.122 0x0348 POWER Analog Control Register (Default Value: 0x8000\_3325)

The register is not controlled by the clock and reset of Audio Codec, only controlled by the clock and reset of system bus.

| Offset: 0x0348 |            |             | Register Name: POWER_REG                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                  |
| 31             | R/W        | 0x1         | ALDO_EN<br>ALDO Enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                          |
| 30             | R/W        | 0x0         | HPLDO_EN<br>HPLDO Enable<br>0: Disabled<br>1: Enabled                                                                                                                                                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | VAR1SPEEDUP_DOWN_Further_CTRL<br>VAR1 Speedup Down Further Control In Adda Analog<br>0: The digital logic signal input by the digital-analog interface pin controls the var1_speedup_down function (that is, the var1 signal is rapidly pulled up/down)<br>1: Writing '1' can finish the var1_speedup_down function (ignore the control of the digital-analog interface pin) |

| Offset: 0x0348 |            |             | Register Name: POWER_REG                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 28:17          | /          | /           | /                                                                                                                                                                            |
| 16             | R          | 0x0         | AVCCPOR<br>Avccpor Monitor                                                                                                                                                   |
| 15             | /          | /           | /                                                                                                                                                                            |
| 14:12          | R/W        | 0x3         | ALDO_OUTPUT_VOLTAGE<br>ALDO Output Voltage Control<br>000: 2.03 V<br>001: 1.95 V<br>010: 1.87 V<br>011: 1.80 V<br>100: 1.73 V<br>101: 1.67 V<br>110: 1.61 V<br>111: 1.56 V   |
| 11             | /          | /           | /                                                                                                                                                                            |
| 10:8           | R/W        | 0x3         | HPLDO_OUTPUT_VOLTAGE<br>HPLDO Output Voltage Control<br>000: 2.03 V<br>001: 1.95 V<br>010: 1.87 V<br>011: 1.80 V<br>100: 1.73 V<br>101: 1.67 V<br>110: 1.61 V<br>111: 1.56 V |
| 7:0            | R/W        | 0x25        | BG_TRIM<br>BG Output Voltage Trimming<br>Only low 6-bit is used. The BG output voltage range is from 0.7 V to 1.208 V.                                                       |

#### 8.4.6.123 0x034C ADC Current Analog Control Register (Default Value: 0x0015\_1515)

| Offset: 0x034C |            |             | Register Name: ADC_CUR_REG |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:22          | /          | /           | /                          |

| Offset: 0x034C |            |             | Register Name: ADC_CUR_REG                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 21:20          | R/W        | 0x1         | ADC3_IOPMIC2<br>ADC3 OP MIC2 Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA  |
| 19:18          | R/W        | 0x1         | ADC3_OUTPUT_CURRENT<br>ADC3 OP MIC1 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |
| 17:16          | R/W        | 0x1         | ADC3_OUTPUT_CURRENT<br>ADC3 OP MIC2 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |
| 15:14          | /          | /           | /                                                                                                                                                                                       |
| 13:12          | R/W        | 0x1         | ADC2_IOPMIC2<br>ADC2 OP MIC2 Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA. |
| 11:10          | R/W        | 0x1         | ADC2_OUTPUT_CURRENT<br>ADC2 OP MIC1 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |

| Offset: 0x034C |            |             | Register Name: ADC_CUR_REG                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 9:8            | R/W        | 0x1         | ADC2_OUTPUT_CURRENT<br>ADC2 OP MIC2 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |
| 7:6            | /          | /           | /                                                                                                                                                                                       |
| 5:4            | R/W        | 0x1         | ADC1_IOPMIC2<br>ADC1 OP MIC2 Bias Current Select<br>00: 1.50*IOPADC<br>01: 1.75*IOPADC<br>10: 2.00*IOPADC<br>11: 2.25*IOPADC<br>IOPADC is defined by ADC1_REG<15:14> from 1 uA to 4 uA. |
| 3:2            | R/W        | 0x1         | ADC1_OUTPUT_CURRENT<br>ADC1 OP MIC1 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |
| 1:0            | R/W        | 0x1         | ADC1_OUTPUT_CURRENT<br>ADC1 OP MIC2 Output Current Select<br>00: 15I<br>01: 20I<br>10: 35I<br>11: 40I<br>I=7 uA                                                                         |

# Contents

|       |                              |      |
|-------|------------------------------|------|
| 9     | Interfaces .....             | 870  |
| 9.1   | TWI .....                    | 870  |
| 9.1.1 | Overview .....               | 870  |
| 9.1.2 | Block Diagram .....          | 870  |
| 9.1.3 | Functional Description ..... | 872  |
| 9.1.4 | Programming Guidelines.....  | 878  |
| 9.1.5 | Register List.....           | 881  |
| 9.1.6 | Register Description .....   | 882  |
| 9.2   | UART.....                    | 897  |
| 9.2.1 | Overview .....               | 897  |
| 9.2.2 | Block Diagram .....          | 897  |
| 9.2.3 | Functional Description ..... | 898  |
| 9.2.4 | Programming Guidelines.....  | 904  |
| 9.2.5 | Register List.....           | 907  |
| 9.2.6 | Register Description .....   | 909  |
| 9.3   | SPI.....                     | 938  |
| 9.3.1 | Overview .....               | 938  |
| 9.3.2 | Block Diagram .....          | 938  |
| 9.3.3 | Functional Description ..... | 940  |
| 9.3.4 | Programming Guidelines.....  | 948  |
| 9.3.5 | Register List.....           | 951  |
| 9.3.6 | Register Description .....   | 952  |
| 9.4   | SPI_DBI.....                 | 973  |
| 9.4.1 | Overview .....               | 973  |
| 9.4.2 | Block Diagram .....          | 973  |
| 9.4.3 | Functional Description ..... | 975  |
| 9.4.4 | Programming Guidelines.....  | 995  |
| 9.4.5 | Register List.....           | 1003 |
| 9.4.6 | Register Description .....   | 1004 |
| 9.5   | USB2.0 DRD .....             | 1036 |

|                                      |      |
|--------------------------------------|------|
| 9.5.1 Overview .....                 | 1036 |
| 9.5.2 Block Diagram .....            | 1037 |
| 9.5.3 Functional Description .....   | 1037 |
| 9.6 USB2.0 HOST .....                | 1039 |
| 9.6.1 Overview .....                 | 1039 |
| 9.6.2 Block Diagram .....            | 1039 |
| 9.6.3 Functional Description .....   | 1040 |
| 9.6.4 Register List.....             | 1040 |
| 9.6.5 EHCI Register Description..... | 1042 |
| 9.6.6 OHCI Register Description..... | 1059 |
| 9.7 GPIO .....                       | 1081 |
| 9.7.1 Overview .....                 | 1081 |
| 9.7.2 Block Diagram .....            | 1081 |
| 9.7.3 Functional Description .....   | 1082 |
| 9.7.4 Register List.....             | 1090 |
| 9.7.5 Register Description .....     | 1092 |
| 9.8 GPADC .....                      | 1183 |
| 9.8.1 Overview.....                  | 1183 |
| 9.8.2 Block Diagram .....            | 1183 |
| 9.8.3 Functional Description .....   | 1184 |
| 9.8.4 Programming Guidelines.....    | 1185 |
| 9.8.5 Register List .....            | 1187 |
| 9.8.6 Register Description .....     | 1188 |
| 9.9 TPADC.....                       | 1196 |
| 9.9.1 Overview .....                 | 1196 |
| 9.9.2 Functional Description .....   | 1196 |
| 9.9.3 Register List .....            | 1202 |
| 9.9.4 Register Description .....     | 1203 |
| 9.10 PWM .....                       | 1211 |
| 9.10.1 Overview .....                | 1211 |
| 9.10.2 Block Diagram .....           | 1211 |
| 9.10.3 Functional Description .....  | 1212 |
| 9.10.4 Programming Guidelines.....   | 1222 |

|                                     |      |
|-------------------------------------|------|
| 9.10.5 Register List.....           | 1223 |
| 9.10.6 Register Description .....   | 1225 |
| 9.11 LEDC .....                     | 1252 |
| 9.11.1 Overview .....               | 1252 |
| 9.11.2 Block Diagram .....          | 1252 |
| 9.11.3 Functional Description ..... | 1253 |
| 9.11.4 Programming Guidelines.....  | 1257 |
| 9.11.5 Register List.....           | 1262 |
| 9.11.6 Register Description .....   | 1262 |
| 9.12 EMAC.....                      | 1273 |
| 9.12.1 Overview .....               | 1273 |
| 9.12.2 Block Diagram .....          | 1273 |
| 9.12.3 Functional Description ..... | 1274 |
| 9.12.4 Programming Guidelines.....  | 1281 |
| 9.12.5 Register List.....           | 1282 |
| 9.12.6 Register Description .....   | 1283 |
| 9.13 CIR Receiver .....             | 1302 |
| 9.13.1 Overview.....                | 1302 |
| 9.13.2 Block Diagram .....          | 1302 |
| 9.13.3 Functional Description ..... | 1303 |
| 9.13.4 Programming Guidelines.....  | 1307 |
| 9.13.5 Register List.....           | 1308 |
| 9.13.6 Register Description .....   | 1308 |
| 9.14 CIR Transmitter .....          | 1314 |
| 9.14.1 Overview .....               | 1314 |
| 9.14.2 Block Diagram .....          | 1314 |
| 9.14.3 Functional Description ..... | 1315 |
| 9.14.4 Programming Guidelines.....  | 1317 |
| 9.14.5 Register List.....           | 1318 |
| 9.14.6 Register Description .....   | 1318 |
| 9.15 CAN .....                      | 1326 |
| Contents.....                       | 1327 |

# Figures

|                                                                   |     |
|-------------------------------------------------------------------|-----|
| Figure 9-1 TWI Block Diagram.....                                 | 871 |
| Figure 9-2 Write Timing in 7-bit Standard Addressing Mode .....   | 873 |
| Figure 9-3 Read Timing in 7-bit Standard Addressing Mode .....    | 873 |
| Figure 9-4 Write Timing in 10-bit Extended Addressing Mode.....   | 874 |
| Figure 9-5 Read Timing in 10-bit Extended Addressing Mode.....    | 874 |
| Figure 9-6 TWI Driver Write Packet Transmission .....             | 875 |
| Figure 9-7 TWI Driver Read Packet Transmission .....              | 876 |
| Figure 9-8 TWI Programming State Diagram .....                    | 878 |
| Figure 9-9 UART Block Diagram .....                               | 898 |
| Figure 9-10 UART Serial Data Format .....                         | 899 |
| Figure 9-11 Application Diagram for RTS/CTS Autoflow Control..... | 900 |
| Figure 9-12 RTS/CTS Autoflow Control Data Format .....            | 900 |
| Figure 9-13 Application Diagram for IrDA Transceiver .....        | 900 |
| Figure 9-14 Serial IrDA Data Format .....                         | 901 |
| Figure 9-15 Application Diagram for RS-485 Transceiver .....      | 901 |
| Figure 9-16 RS-485 Data Format.....                               | 901 |
| Figure 9-17 UART Mode Baud and Error Rates.....                   | 902 |
| Figure 9-18 IrDA Mode Baud and Error Rates.....                   | 903 |
| Figure 9-19 RS485 Mode Baud and Error Rates.....                  | 903 |
| Figure 9-20 SPI Block Diagram .....                               | 939 |
| Figure 9-21 SPI Application Block Diagram .....                   | 941 |
| Figure 9-22 SPI Phase 0 Timing Diagram.....                       | 942 |
| Figure 9-23 SPI Phase 1 Timing Diagram.....                       | 942 |
| Figure 9-24 SPI 3-Wire Mode .....                                 | 943 |
| Figure 9-25 SPI Dual-Input/Dual-Output Mode .....                 | 944 |
| Figure 9-26 SPI Dual I/O Mode.....                                | 944 |
| Figure 9-27 SPI Quad-Input/Quad-Output Mode .....                 | 945 |
| Figure 9-28 SPI Write/Read Data in CPU Mode .....                 | 949 |
| Figure 9-29 SPI Write/Read Data in DMA Mode.....                  | 950 |
| Figure 9-30 SPI_DBI Block Diagram.....                            | 974 |

|                                                                                          |      |
|------------------------------------------------------------------------------------------|------|
| Figure 9-31 SPI Application Block Diagram .....                                          | 977  |
| Figure 9-32 DBI Application Block Diagram .....                                          | 977  |
| Figure 9-33 SPI Phase 0 Timing Diagram.....                                              | 978  |
| Figure 9-34 SPI Phase 1 Timing Diagram.....                                              | 978  |
| Figure 9-35 SPI 3-Wire Mode .....                                                        | 979  |
| Figure 9-36 SPI Dual-Input/Dual-Output Mode .....                                        | 980  |
| Figure 9-37 SPI Dual I/O Mode.....                                                       | 980  |
| Figure 9-38 SPI Quad-Input/Quad-Output Mode .....                                        | 981  |
| Figure 9-39 DBI 3-Line Display Bus Serial Interface Writing Operation Format .....       | 983  |
| Figure 9-40 DBI 3-Line Display Bus Serial Interface 8-bit Reading Operation Format ..... | 984  |
| Figure 9-41 DBI 3-Line Display Bus Serial Interface 24-bit Reading Operation Format..... | 984  |
| Figure 9-42 DBI 3-Line Display Bus Serial Interface 32-bit Reading Operation Format..... | 985  |
| Figure 9-43 DBI 4-Line Display Bus Serial Interface Writing Operation Format .....       | 986  |
| Figure 9-44 DBI 4-Line Display Bus Serial Interface 8-bit Reading Operation Format.....  | 986  |
| Figure 9-45 DBI 4-Line Display Bus Serial Interface 24-bit Reading Operation Format..... | 987  |
| Figure 9-46 DBI 4-Line Display Bus Serial Interface 32-bit Reading Operation Format..... | 987  |
| Figure 9-47 RGB111 3-Line Interface Transmit Video Format .....                          | 988  |
| Figure 9-48 RGB444 3-Line Interface Transmit Video Format .....                          | 988  |
| Figure 9-49 RGB565 3-Line Interface Transmit Video Format .....                          | 989  |
| Figure 9-50 RGB666 3-Line Interface Transmit Video Format .....                          | 989  |
| Figure 9-51 RGB111 4-Line Interface Transmit Video Format.....                           | 990  |
| Figure 9-52 RGB444 4-Line Interface Transmit Video Format .....                          | 990  |
| Figure 9-53 RGB565 4-Line Interface Transmit Video Format .....                          | 991  |
| Figure 9-54 RGB666 4-Line Interface Transmit Video Format .....                          | 991  |
| Figure 9-55 RGB444 2 Data Lane Interface Transmit Video Format.....                      | 992  |
| Figure 9-56 RGB565 2 Data Lane Interface Transmit Video Format.....                      | 993  |
| Figure 9-57 RGB666 2 Data Lane Interface Transmit Video Format 0.....                    | 994  |
| Figure 9-58 RGB666 2 Data Lane Interface Transmit Video Format 1 (ilitek).....           | 994  |
| Figure 9-59 RGB666 2 Data Lane Interface Transmit Video Format 2 (New vision) .....      | 994  |
| Figure 9-60 RGB888 2 Data Lane Interface Transmit Video Format .....                     | 995  |
| Figure 9-61 SPI Write/Read Data in CPU Mode .....                                        | 996  |
| Figure 9-62 SPI Write/Read Data in DMA Mode.....                                         | 997  |
| Figure 9-63 USB2.0 DRD Controller Block Diagram .....                                    | 1037 |

|                                                                        |      |
|------------------------------------------------------------------------|------|
| Figure 9-64 USB2.0 DRD Controller and PHY Connection Diagram .....     | 1038 |
| Figure 9-65 USB2.0 Host Controller Block Diagram.....                  | 1039 |
| Figure 9-66 USB2.0 Host Controller and PHY Connection Diagram.....     | 1040 |
| Figure 9-67 GPIO Block Diagram.....                                    | 1082 |
| Figure 9-68 Pull up/down Logic .....                                   | 1087 |
| Figure 9-69 IO Buffer Strength Diagram .....                           | 1088 |
| Figure 9-70 GPADC Block Diagram.....                                   | 1183 |
| Figure 9-71 GPADC Clock and Timing Requirement .....                   | 1185 |
| Figure 9-72 GPADC Initial Process.....                                 | 1186 |
| Figure 9-73 TPADC Single-Ended Mode for AUX ADC.....                   | 1197 |
| Figure 9-74 TPADC Differential Mode for Touch Panel.....               | 1198 |
| Figure 9-75 Single Touch X-Coordinate Measurement for Touch Panel..... | 1198 |
| Figure 9-76 Dual Touch Detection for Touch Panel .....                 | 1199 |
| Figure 9-77 Touch Pressure Measurement for Touch Panel .....           | 1200 |
| Figure 9-78 Pen Down Detection for Touch Panel.....                    | 1201 |
| Figure 9-79 Median and Averaging Filter Size .....                     | 1201 |
| Figure 9-80 Median and Averaging Filter Example .....                  | 1202 |
| Figure 9-81 PWM Block Diagram .....                                    | 1212 |
| Figure 9-82 PWM01 Clock Controller Diagram .....                       | 1213 |
| Figure 9-83 PWM01 Output Logic Module Diagram.....                     | 1214 |
| Figure 9-84 PWM0 High Level Active State.....                          | 1215 |
| Figure 9-85 PWM0 Low Level Active State .....                          | 1216 |
| Figure 9-86 Phase of PWM0 High Level Active State.....                 | 1216 |
| Figure 9-87 PWM0 Output Waveform in Pulse Mode and Cycle Mode .....    | 1217 |
| Figure 9-88 PWM01 Complementary Pair Output.....                       | 1218 |
| Figure 9-89 Dead-time Output Waveform.....                             | 1219 |
| Figure 9-90 Group 0–3 PWM Signal Output .....                          | 1220 |
| Figure 9-91 PWM01 Capture Logic Module Diagram .....                   | 1220 |
| Figure 9-92 PWM0 Channel Capture Timing.....                           | 1221 |
| Figure 9-93 LEDC Block Diagram .....                                   | 1252 |
| Figure 9-94 LEDC Package Output Timing Diagram .....                   | 1253 |
| Figure 9-95 LEDC 1-frame Output Timing Diagram.....                    | 1254 |
| Figure 9-96 LEDC Input Data Structure .....                            | 1254 |

|                                                                |      |
|----------------------------------------------------------------|------|
| Figure 9-97 LEDC Typical Circuit.....                          | 1254 |
| Figure 9-98 LEDC Data Input Code .....                         | 1255 |
| Figure 9-99 LEDC Data Transfer Mode.....                       | 1255 |
| Figure 9-100 LEDC Normal Configuration Process.....            | 1258 |
| Figure 9-101 LEDC Timeout Abnormal Processing Flow .....       | 1260 |
| Figure 9-102 FIFO Overflow Abnormal Processing Flow.....       | 1261 |
| Figure 9-103 EMAC Block Diagram .....                          | 1274 |
| Figure 9-104 EMAC Typical Application .....                    | 1276 |
| Figure 9-105 EMAC RX/TX Descriptor List.....                   | 1277 |
| Figure 9-106 CIR_RX Block Diagram.....                         | 1302 |
| Figure 9-107 CIR_RX Clock System.....                          | 1303 |
| Figure 9-108 CIR_RX Application Diagram .....                  | 1303 |
| Figure 9-109 NEC Protocol .....                                | 1304 |
| Figure 9-110 Logical ‘0’ and Logical ‘1’ of NEC Protocol ..... | 1304 |
| Figure 9-111 ATHR Definition .....                             | 1305 |
| Figure 9-112 ITHR Definition .....                             | 1305 |
| Figure 9-113 NTHR Definition .....                             | 1305 |
| Figure 9-114 APAM Definition .....                             | 1306 |
| Figure 9-115 CIR Receiver Process .....                        | 1307 |
| Figure 9-116 CIR_TX Block Diagram .....                        | 1314 |
| Figure 9-117 CIR_TX Clock System .....                         | 1315 |
| Figure 9-118 Definitions of Logical “1” and Logical “0”.....   | 1316 |
| Figure 9-119 CIR Message Timing Diagram.....                   | 1316 |
| Figure 9-120 CIR Transmitter Process .....                     | 1317 |

# Tables

|                                                    |      |
|----------------------------------------------------|------|
| Table 9-1 TWI Sub-blocks.....                      | 871  |
| Table 9-2 TWI External Signals.....                | 872  |
| Table 9-3 TWI Clock Sources.....                   | 872  |
| Table 9-4 UART External Signals .....              | 898  |
| Table 9-5 UART Clock Sources.....                  | 899  |
| Table 9-6 SPI Sub-blocks .....                     | 939  |
| Table 9-7 SPI External Signals .....               | 940  |
| Table 9-8 SPI Clock Sources.....                   | 940  |
| Table 9-9 SPI Transmit Format.....                 | 941  |
| Table 9-10 SPI Old Sample Mode and Run Clock ..... | 946  |
| Table 9-11 SPI New Sample Mode .....               | 946  |
| Table 9-12 SPI_DBI Sub-blocks.....                 | 974  |
| Table 9-13 SPI_DBI External Signals.....           | 975  |
| Table 9-14 SPI_DBI Clock Sources.....              | 976  |
| Table 9-15 SPI Transmit Format.....                | 978  |
| Table 9-16 SPI Old Sample Mode and Run Clock ..... | 982  |
| Table 9-17 SPI New Sample Mode .....               | 982  |
| Table 9-18 USB2.0 DRD External Signals.....        | 1037 |
| Table 9-19 USB2.0 Host External Signals .....      | 1040 |
| Table 9-20 Multi-function Port .....               | 1082 |
| Table 9-21 PB Multiplex Function .....             | 1084 |
| Table 9-22 PC Multiplex Function .....             | 1084 |
| Table 9-23 PD Multiplex Function.....              | 1084 |
| Table 9-24 PE Multiplex Function .....             | 1085 |
| Table 9-25 PF Multiplex Function .....             | 1085 |
| Table 9-26 PG Multiplex Function.....              | 1086 |
| Table 9-27 Port Function.....                      | 1087 |
| Table 9-28 GPADC External Signals.....             | 1184 |
| Table 9-29 GPADC Clock Sources .....               | 1184 |
| Table 9-30 TPADC External Signals.....             | 1196 |

|                                                        |      |
|--------------------------------------------------------|------|
| Table 9-31 PWM External Signals .....                  | 1212 |
| Table 9-32 LEDC Sub-blocks .....                       | 1252 |
| Table 9-33 LEDC External Signals .....                 | 1253 |
| Table 9-34 LEDC Clock Sources .....                    | 1253 |
| Table 9-35 EMAC Pin Mapping.....                       | 1274 |
| Table 9-36 EMAC RGMII Pin List .....                   | 1275 |
| Table 9-37 EMAC RMII Pin List.....                     | 1275 |
| Table 9-38 EMAC Clock Characteristics.....             | 1276 |
| Table 9-39 EMAC_EPHY_CLK_REG0 Configuration Value..... | 1281 |
| Table 9-40 CIR_RX External Signals .....               | 1303 |
| Table 9-41 CIR_TX External Signals .....               | 1315 |

## 9 Interfaces

### 9.1 TWI

#### 9.1.1 Overview

The Two Wire Interface (TWI) provides an interface between a CPU and any TWI-bus-compatible device that connects via the TWI bus. The TWI is designed to be compatible with the standard I2C bus protocol. The communication of the TWI is carried out by a byte-wise mode based on interrupt polled handshaking. Each device on the TWI bus is recognized by a unique address and can operate as either transmitter or receiver, a device connected to the TWI bus can be considered as master or slave when performing data transfers. Note that a master device is a device that initiates a data transfer on the bus and generates the clock signals to permit the transfer. During this transfer, any device addressed by this master is considered a slave.

The TWI has the following features:

- Compliant with I2C bus standard
- Supports standard mode (up to 100 kbit/s) and fast mode (up to 400 kbit/s)
- Supports 7-bit and 10-bit device addressing modes
- Supports master mode or slave mode
- Master mode features:
  - Supports the bus arbitration in the case of multiple master devices
  - Supports clock synchronization and bit and byte waiting
  - Supports packet transmission and DMA
- Slave mode features:
  - Interrupt on address detection
- The TWI controller includes one TWI engine and one TWI driver. And the TWI driver supports packet transmission and DMA mode when TWI works in master mode

#### 9.1.2 Block Diagram

Figure 9-1 shows the block diagram of TWI.

**Figure 9-1 TWI Block Diagram**

TWI contains the following sub-blocks:

**Table 9-1 TWI Sub-blocks**

| Sub-block | Description                                                                     |
|-----------|---------------------------------------------------------------------------------|
| RESET     | Module reset signal                                                             |
| INT       | Module output interrupt signal                                                  |
| CFG_REG   | Module configuration register in TWI                                            |
| PE        | Packet encoding/decoding                                                        |
| CCU       | Module clock controller unit                                                    |
| SEND_FIFO | The register address bytes and the written data bytes are buffered in SEND_FIFO |
| RECV_FIFO | The read data bytes are buffered in RECV_FIFO                                   |

The controller includes TWI engine and TWI driver. Each time the TWI engine sends a START signal, a STOP signal, or a BYTE data, or a corresponding ACK, the TWI engine will generate an interrupt, and wait for the CPU to process and clear the interrupt before the next START, STOP, or BYTE, ACK transmission can be performed. Therefore, when a device communication is completed, many interrupts will be generated, and the CPU needs to wait for the previous interrupt before it can configure the next one. The TWI driver defines each communication with the device as a packet transmission. The CPU can directly configure the slave address, register address and data transmission for one or more package transmissions without waiting for interruption, then start the TWI driver, and the TWI driver can control the TWI engine to complete a pre-configured communication, and report an interrupt to the CPU after completion.

### 9.1.3 Functional Description

#### 9.1.3.1 External Signals

The TWI controller has 4 TWI modules called TWI0, TWI1, TWI2, and TWI3. The following table describes the external signals of the TWI. The TWIn-SCK and TWIn-SDA are bidirectional I/O, when the TWI is configured as a master device, the TWIn-SCK is an output pin; when the TWI is configurable as a slave device, the TWIn-SCK is an input pin. When using TWI, the corresponding PADs are selected as TWI function via section 9.7 “[GPIO](#)”.

**Table 9-2 TWI External Signals**

| Signal   | Description       | Type    |
|----------|-------------------|---------|
| TWI0-SCK | TWI0 Clock Signal | I/O, OD |
| TWI0-SDA | TWI0 Serial Data  | I/O, OD |
| TWI1-SCK | TWI1 Clock Signal | I/O, OD |
| TWI1-SDA | TWI1 Serial Data  | I/O, OD |
| TWI2-SCK | TWI2 Clock Signal | I/O, OD |
| TWI2-SDA | TWI2 Serial Data  | I/O, OD |
| TWI3-SCK | TWI3 Clock Signal | I/O, OD |
| TWI3-SDA | TWI3 Serial Data  | I/O, OD |

#### 9.1.3.2 Clock Sources

Each TWI controller has an input clock source. The following table describes the clock sources for TWI. After selecting a proper clock, users must open the gating of TWI and release the corresponding reset bit.

For more details on the clock setting, configuration, and gating information, see section 3.3 “[CCU](#)”.

**Table 9-3 TWI Clock Sources**

| Clock Sources | Description                                         |
|---------------|-----------------------------------------------------|
| APB1 Bus      | TWI clock source. Refer to CCU for details on APB1. |

#### 9.1.3.3 Write/Read Timing in Standard and Extended Addressing Mode

This section is the 7-bit/10-bit addressing mode of the entire TWI protocol to read and write device registers.

It can be achieved by directly using the TWI engine or using the TWI driver to control the TWI engine.

Figure 9-2 describes the write timing in 7-bit standard addressing mode.

**Figure 9-2 Write Timing in 7-bit Standard Addressing Mode**

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit , register addr = 8-bit, data = n-byte


 from master to slave

S: START condition

A: acknowledge(SDA LOW)

 from slave to master

P: STOP condition

Ā: not acknowledge(SDA HIGH)

**Figure 9-3 describes the read timing in 7-bit standard address mode.****Figure 9-3 Read Timing in 7-bit Standard Addressing Mode**

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit, register addr = 8-bit, data = n-byte


 from master to slave

S: START condition

A: acknowledge(SDA LOW)

 from slave to master

Sr: RE-START condition

Ā: not acknowledge(SDA HIGH)

**Figure 9-4 describes the write timing in 10-bit extended address mode.**

**Figure 9-4 Write Timing in 10-bit Extended Addressing Mode**

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

 from master to slave

S: START condition

A: acknowledge(SDA LOW)

 from slave to master

P: STOP condition

Ā: not acknowledge(SDA HIGH)

**Figure 9-5 describes the read timing in 10-bit extended address mode.****Figure 9-5 Read Timing in 10-bit Extended Addressing Mode**

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

 from master to slave

S: START condition

A: acknowledge(SDA LOW)

 from slave to master

Sr: RE-START condition

P: STOP condition

Ā: not acknowledge(SDA HIGH)

### 9.1.3.4 Write/Read Packet Transmission of TWI Driver

The TWI driver is only supported for master mode. When the TWI works in master mode, the TWI driver drives the TWI engine for one or more packet transmission instead of the CPU host. Packet transmission is defined in the following figures. The register address bytes and the written data bytes are buffered in SEND\_FIFO, the read data bytes are buffered in RECV\_FIFO.

Figure 9-6 TWI Driver Write Packet Transmission



Figure 9-7 TWI Driver Read Packet Transmission



### 9.1.3.5 Master and Slave Mode of TWI Engine

In Master mode, the CPU host controls the TWI engine by writing command and data to its registers. The TWI engine transmits an interrupt to CPU when each time a byte transfer is done or a START/STOP command is detected. The CPU host can poll the status register if the interrupt mechanism is not disabled by the CPU host.

When the CPU host wants to start a bus transfer, it initiates a bus START to enter the master mode by setting [TWI\\_CNTR\[M\\_STA\]](#) to high. The TWI engine will assert the INT line and [TWI\\_CNTR\[INT\\_FLAG\]](#) to indicate a completion for the START command and each consequent byte transfer. At each interrupt, the CPU host needs

to check the current state by the [TWI\\_STAT](#) register. A transfer must conclude with the STOP command by setting [TWI\\_CNTR\[M\\_STP\]](#) to high.

In Slave mode, the TWI engine also constantly samples the bus and look for its own slave address during addressing cycles. Once a match is found, it is addressed, and the TWI engine interrupts the CPU host with the corresponding status. Upon request, the CPU host should read the status, read/write the [TWI\\_DATA](#) register, and set the [TWI\\_CNTR](#) register. After each byte transfer, a slave device always stops the operation of the remote master by holding the next low pulse on the SCL line until the CPU host responds to the status of the previous byte transfer or START command.

#### 9.1.3.6 Generation of Repeated Start

After the data transfer, if the master still requires the bus, it can signal another Start followed by another slave address without signaling a Stop.

#### 9.1.3.7 Programming State Diagram

Figure 9-8 shows the TWI programming state diagram. For the value between two states, see the [TWI\\_STAT](#) register in section 9.1.6.5.

M\_SEND\_S: master sends START signal;

M\_SEND\_ADDR: master sends slave address;

M\_SEND\_XADD: master sends slave extended address;

M\_SEND\_SR: master repeated start;

M\_SEND\_DATA: master sends data;

M\_SEND\_P: master sends STOP signal;

M\_RECV\_DATA: master receives data;

ARB\_LOST: Arbitration lost;

C\_IDLE: Idle.

Figure 9-8 TWI Programming State Diagram



### 9.1.4 Programming Guidelines

The TWI controller operates in an 8-bit data format. The data on the TWI\_SDA line is always 8 bits long. At first, the TWI controller sends a start condition. When in the addressing formats of 7-bit, the TWI sends out an 8-bit message which includes 7 MSB slave address and 1 LSB read/write flag. The least significant of the slave address indicates the direction of transmission. When the TWI works in 10-bit slave address mode, the operation will be divided into two steps, for details on the operation, refer to register description in Section 9.1.6.1 and 9.1.6.2.

The following takes the TWI module in the CPUX domain as an example.

#### 9.1.4.1 Initialization for TWI Engine

To initialize the TWI engine, perform the following steps:

- Step 1** Configure corresponding GPIO multiplex function as TWI mode.
- Step 2** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_GATING\]](#) in CCU module to 0 to close TWIn clock.
- Step 3** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_RST\]](#) in CCU module to 0, then set to 1 to reset TWIn.

- Step 4** For TWIn, set [TWI\\_BGR\\_REG](#)[TWIn\_GATING] in CCU module to 1 to open TWIn clock.
- Step 5** Configure [TWI\\_CCR](#)[CLK\_M] and [TWI\\_CCR](#)[CLK\_N] to get the needed rate (The clock source of TWI is from APB1).
- Step 6** Configure [TWI\\_CNTR](#)[BUS\_EN] and [TWI\\_CNTR](#)[A\_ACK], when using interrupt mode, set [TWI\\_CNTR](#)[INT\_EN] to 1, and register the system interrupt through GIC module. In slave mode, configure [TWI\\_ADDR](#) and [TWI\\_XADDR](#) registers to finish TWI initialization configuration.

#### 9.1.4.2 Writing Data Operation for TWI Engine

To write data to the device, perform the following steps:

- Step 1** Clear [TWI\\_EFR](#) register, and configure [TWI\\_CNTR](#)[M\_STA] to 1 to transmit the START signal.
- Step 2** After the START signal is transmitted, the first interrupt is triggered, then write device ID to [TWI\\_DATA](#) (For a 10-bit device ID, firstly write the first byte ID, secondly write the second byte ID in the next interrupt).
- Step 3** The Interrupt is triggered again after device ID transmission completes, write device data address to be read to [TWI\\_DATA](#) (For a 16-bit address, firstly write the first-byte address, secondly write the second-byte address).
- Step 4** Interrupt is triggered after data address transmission completes, write data to be transmitted to [TWI\\_DATA](#) (For consecutive write data operation, every byte transmission completion triggers interrupt, during interrupt write the next byte data to [TWI\\_DATA](#)).
- Step 5** After transmission completes, write [TWI\\_CNTR](#)[M\_STP] to 1 to transmit the STOP signal and end this write-operation.

#### 9.1.4.3 Reading Data Operation for TWI Engine

To read data from the device, perform the following steps:

- Step 1** Clear [TWI\\_EFR](#) register, and set [TWI\\_CNTR](#)[A\_ACK] to 1, and configure [TWI\\_CNTR](#)[M\_STA] to 1 to transmit the START signal.
- Step 2** After the START signal is transmitted, the first interrupt is triggered, then write device ID to [TWI\\_DATA](#) (For a 10-bit device ID, firstly write the first-byte ID, secondly write the second-byte ID in the next interrupt).
- Step 3** The Interrupt is triggered again after device ID transmission completes, write device data address to be read to [TWI\\_DATA](#) (For a 16-bit address, firstly write the first-byte address, secondly write the second-byte address).

- Step 4** The Interrupt is triggered after data address transmission completes, write [TWI\\_CNTR](#)[M\_STA] to 1 to transmit new START signal, and after interrupt triggers, write device ID to [TWI\\_DATA](#) to start read-operation.
- Step 5** After device address transmission completes, each receive completion will trigger an interrupt, in turn, read [TWI\\_DATA](#) to get data, when receiving the previous interrupt of the last byte data, clear [C:\Users\zengjing\Downloads\ Hlk50046436 - Hlk50051279\[A\\_ACK\]](#) to stop acknowledge signal of the last byte.
- Step 6** Write [TWI\\_CNTR](#)[M\_STP] to 1 to transmit the STOP signal and end this read-operation.

#### 9.1.4.4 Initialization for TWI Driver

To initialize the TWI driver, perform the following steps:

- Step 1** Configure corresponding GPIO multiplex function as TWI mode.
- Step 2** For TWIn, set [TWI\\_BGR\\_REG](#)[TWIn\_GATING] in CCU module to 0 to close TWIn clock.
- Step 3** For TWIn, set [TWI\\_BGR\\_REG](#)[TWIn\_RST] in CCU module to 0, then set to 1 to reset TWIn.
- Step 4** For TWIn, set [TWI\\_BGR\\_REG](#)[TWIn\_GATING] in CCU module to 1 to open TWIn clock.
- Step 5** Set [TWI\\_DRV\\_CTRL](#)[TWI\_DRV\_EN] to 1 to enable the TWI driver.
- Step 6** Configure [TWI\\_DRV\\_BUS\\_CTRL](#)[CLK\_M] and [TWI\\_DRV\\_BUS\\_CTRL](#)[CLK\_N] to get the needed rate (The clock source of TWI is from APB1).
- Step 7** Set [TWI\\_DRV\\_CTRL](#)[RESTART\_MODE] to 0 and [C:\Users\zengjing\Downloads\ Hlk50051373 - Hlk50051463](#)[READ\_TRAN\_MODE] to 1, set [TWI\\_DRV\\_INT\\_CTRL](#)[TRAN\_COM\_INT\_EN] to 1.
- Step 8** When using DMA for data transmission, set [TWI\\_DRV\\_DMA\\_CFG](#)[DMA\_RX\_EN] and [TWI\\_DRV\\_DMA\\_CFG](#)[DMA\_TX\_EN] to 1, and configure [TWI\\_DRV\\_DMA\\_CFG](#)[RX\_TRIGGER] and [TWI\\_DRV\\_DMA\\_CFG](#)[TX\_TRIGGER] to set the thresholds of RXFIFO and TXFIFO.

#### 9.1.4.5 Writing Packet Transmission for TWI Driver

To write package to the device, perform the following steps:

- Step 1** Configure [TWI\\_DRV\\_SLV](#)[SLV\_ID] to set the device ID, and configure [TWI\\_DRV\\_SLV](#)[CMD] to 0 to set the write operation.
- Step 2** Configure [TWI\\_DRV\\_FMT](#)[ADDR\_BYTE] according to the address width of the device register, and [TWI\\_DRV\\_FMT](#)[DATA\_BYTE] according to the written data count in a packet.
- Step 3** Configure [TWI\\_DRV\\_CFG](#)[PACKET\_CNT] to set the written packet number.

- Step 4** Configure DMA channel, including TWI TXFIFO, device register address, and the written data.
- Step 5** Set <C:\Users\zengjing\Downloads\Hlk50051463 - Hlk50051932>[START\_TRAN] to 1 to start TWI Driver transmission.
- Step 6** When TWI driver transmission completes, the interrupt is triggered, it indicates that the write packet transmission ends.

#### 9.1.4.6 Reading Packet Transmission for TWI Driver

To read package from the device, perform the following steps:

- Step 1** Configure [TWI\\_DRV\\_SLV](#)[SLV\_ID] to set the device ID, and configure [TWI\\_DRV\\_SLV](#)[CMD] to 1 to set the read operation.
- Step 2** Configure [TWI\\_DRV\\_FMT](#)[ADDR\_BYTE] according to the address width of the device register, and [TWI\\_DRV\\_FMT](#)[DATA\_BYTE] according to the read data count in a packet.
- Step 3** Configure [TWI\\_DRV\\_CFG](#)[PACKET\_CNT] to set the read packet number.
- Step 4** Configure DMA channel, including TWI TXFIFO, TWI RXFIFO, device register address and the read data.
- Step 5** Set <C:\Users\zengjing\Downloads\Hlk50051463 - Hlk50051932>[START\_TRAN] to 1 to start TWI Driver transmission.
- Step 6** When TWI driver transmission completes, the interrupt is triggered, it indicates that the read packet transmission ends.

#### 9.1.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| TWI0        | 0x02502000   |
| TWI1        | 0x02502400   |
| TWI2        | 0x02502800   |
| TWI3        | 0x02502C00   |

| Register Name | Offset | Description                         |
|---------------|--------|-------------------------------------|
| TWI_ADDR      | 0x0000 | TWI Slave Address Register          |
| TWI_XADDR     | 0x0004 | TWI Extended Slave Address Register |
| TWI_DATA      | 0x0008 | TWI Data Byte Register              |
| TWI_CNTR      | 0x000C | TWI Control Register                |

| Register Name         | Offset | Description                                 |
|-----------------------|--------|---------------------------------------------|
| TWI_STAT              | 0x0010 | TWI Status Register                         |
| TWI_CCR               | 0x0014 | TWI Clock Control Register                  |
| TWI_SRST              | 0x0018 | TWI Software Reset Register                 |
| TWI_EFR               | 0x001C | TWI Enhance Feature Register                |
| TWI_LCR               | 0x0020 | TWI Line Control Register                   |
| TWI_DRV_CTRL          | 0x0200 | TWI_DRV Control Register                    |
| TWI_DRV_CFG           | 0x0204 | TWI_DRV Transmission Configuration Register |
| TWI_DRV_SLV           | 0x0208 | TWI_DRV Slave ID Register                   |
| TWI_DRV_FMT           | 0x020C | TWI_DRV Packet Format Register              |
| TWI_DRV_BUS_CTRL      | 0x0210 | TWI_DRV Bus Control Register                |
| TWI_DRV_INT_CTRL      | 0x0214 | TWI_DRV Interrupt Control Register          |
| TWI_DRV_DMA_CFG       | 0x0218 | TWI_DRV DMA Configure Register              |
| TWI_DRV_FIFO_CON      | 0x021C | TWI_DRV FIFO Content Register               |
| TWI_DRV_SEND_FIFO_ACC | 0x0300 | TWI_DRV Send Data FIFO Access Register      |
| TWI_DRV_RECV_FIFO_ACC | 0x0304 | TWI_DRV Receive Data FIFO Access Register   |

### 9.1.6 Register Description

#### 9.1.6.1 0x0000 TWI Slave Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TWI_ADDR                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                                                                                               |
| 7:1            | R/W        | 0x0         | SLA<br>Slave Address<br>For 7-bit addressing, the bit[7:1] indicates:<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0<br>For 10-bit addressing, the bit[7:1] indicates:<br>1, 1, 1, 1, 0, SLAX[9:8] |
| 0              | R/W        | 0x0         | GCE<br>General Call Address Enable<br>0: Disable<br>1: Enable                                                                                                                                   |



For 7-bit addressing:

SLA6 – SLA0 is the 7-bit address of the TWI in slave mode. When the TWI receives this address after a START condition, it will generate an interrupt and enter slave mode. (SLA6 corresponds to the first bit received from the TWI bus.) If GCE is set to ‘1’, the TWI will also recognize the general call address (00h).

For 10-bit addressing:

When the address received starts with b'11110, the TWI recognizes b'11110 as the first part of a 10-bit address and if the next two bits match ADDR[2:1] (For example, SLAX9 and SLAX8 for the extended address of the device), it sends an ACK. (The device does not generate an interrupt at this point.) If the next byte of the address matches the XADDR register (SLAX7 – SLAX0), the TWI generates an interrupt and goes into slave mode.

#### 9.1.6.2 0x0004 TWI Extend Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TWI_XADDR                  |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:8           | /          | /           | /                                         |
| 7:0            | R/W        | 0x0         | SLAX<br>Extend Slave Address<br>SLAX[7:0] |

#### 9.1.6.3 0x0008 TWI Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TWI_DATA                       |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:8           | /          | /           | /                                             |
| 7:0            | R/W        | 0x0         | TWI_DATA<br>Data byte transmitted or received |

#### 9.1.6.4 0x000C TWI Control Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: TWI_CNTR |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:8           | /          | /           | /                       |

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7              | R/W        | 0x0         | <p>INT_EN</p> <p>Interrupt Enable</p> <p>0: The interrupt line always low</p> <p>1: The interrupt line will go high when INT_FLAG is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6              | R/W        | 0x0         | <p>BUS_EN</p> <p>TWI Bus Enable</p> <p>0: The TWI bus SDA/SCL is ignored and the TWI controller will not respond to any address on the bus.</p> <p>1: The TWI will respond to call to its slave address – and to the general call address if the GCE bit in the ADDR register is set.</p> <p><b>Note: In master operation mode, this bit should be set to '1'.</b></p>                                                                                                                                                                                                                                                                                                              |
| 5              | R/WAC      | 0x0         | <p>M_STA</p> <p>Master Mode Start</p> <p>When the M_STA is set to '1', the TWI controller enters master mode and will transmit a START condition on the bus when the bus is free. If the M_STA bit is set to '1' when the TWI controller is already in master mode and one or more bytes have been transmitted, then a repeated START condition will be sent. If the M_STA bit is set to '1' when the TWI is accessed in slave mode, the TWI will complete the data transfer in slave mode then enter master mode when the bus has been released.</p> <p>The M_STA bit is cleared automatically after a START condition has been sent. Writing a '0' to this bit has no effect.</p> |
| 4              | R/W1C      | 0x0         | <p>M_STP</p> <p>Master Mode Stop</p> <p>If the M_STP is set to '1' in master mode, a STOP condition is transmitted on the TWI bus. If the M_STP bit is set to '1' in slave mode, the TWI will indicate if a STOP condition has been received, but no STOP condition will be transmitted on the TWI bus. If both M_STA and M_STP bits are set, the TWI will first transmit the STOP condition (if in master mode), then transmit the START condition.</p> <p>The M_STP bit is cleared automatically. Writing a '0' to this bit has no effect.</p>                                                                                                                                    |

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3              | R/W1C      | 0x0         | <p>INT_FLAG<br/>Interrupt Flag</p> <p>The INT_FLAG is automatically set to '1' when any of the 28 (out of the possible 29) states is entered (see 'STAT Register' below). The state that does not set INT_FLAG is state F8h. If the INT_EN bit is set, the interrupt line goes high when INT_FLAG is set to '1'. If the TWI is operating in slave mode, the data transfer is suspended when INT_FLAG is set and the low period of the TWI bus clock line (SCL) is stretched until '1' is written to INT_FLAG. The TWI clock line is then released and the interrupt line goes low.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2              | R/W        | 0x0         | <p>A_ACK<br/>Assert Acknowledge</p> <p>When A_ACK is set to '1', an Acknowledge (low level on SDA) will be sent during the acknowledge clock pulse on the TWI bus if:</p> <ul style="list-style-type: none"> <li>(1). Either the whole of a matching 7-bit slave address or the first or the second byte of a matching 10-bit slave address has been received.</li> <li>(2). The general call address has been received and the GCE bit in the ADDR register is set to '1'.</li> <li>(3). A data byte has been received in master or slave mode.</li> </ul> <p>When A_ACK is '0', a Not Acknowledge (high level on SDA) will be sent when a data byte is received in master or slave mode.</p> <p>If A_ACK is cleared to '0' in slave transmitter mode, the byte in the DATA register is assumed to be the 'last byte'. After this byte has been transmitted, the TWI will enter state C8h then return to the idle state (status code F8h) when INT_FLAG is cleared.</p> <p>The TWI will not respond as a slave unless A_ACK is set.</p> |
| 1              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0              | R/W        | 0x0         | <p>CLK_COUNT_MODE</p> <p>0: scl clock high period count on oscl<br/>1: scl clock high period count on iscl</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

#### 9.1.6.5 0x0010 TWI Status Register (Default Value: 0x0000\_00F8)

| Offset: 0x0010 |            |             | Register Name: TWI_STAT |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:8           | /          | /           | /                       |

| Offset: 0x0010 |            |             | Register Name: TWI_STAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:0            | R          | 0xF8        | STA<br>Status Information Byte<br>Code Status<br>0x00: Bus error<br>0x08: START condition transmitted<br>0x10: Repeated START condition transmitted<br>0x18: Address + Write bit transmitted, ACK received<br>0x20: Address + Write bit transmitted, ACK not received<br>0x28: Data byte transmitted in master mode, ACK received<br>0x30: Data byte transmitted in master mode, ACK not received<br>0x38: Arbitration lost in address or data byte<br>0x40: Address + Read bit transmitted, ACK received<br>0x48: Address + Read bit transmitted, ACK not received<br>0x50: Data byte received in master mode, ACK transmitted<br>0x58: Data byte received in master mode, not ACK transmitted<br>0x60: Slave address + Write bit received, ACK transmitted<br>0x68: Arbitration lost in the address as master, slave address + Write bit received, ACK transmitted<br>0x70: General Call address received, ACK transmitted<br>0x78: Arbitration lost in the address as master, General Call address received, ACK transmitted<br>0x80: Data byte received after slave address received, ACK transmitted<br>0x88: Data byte received after slave address received, not ACK transmitted<br>0x90: Data byte received after General Call received, ACK transmitted<br>0x98: Data byte received after General Call received, not ACK transmitted<br>0xA0: STOP or repeated START condition received in slave mode<br>0xA8: Slave address + Read bit received, ACK transmitted<br>0xB0: Arbitration lost in the address as master, slave address + Read bit received, ACK transmitted<br>0xB8: Data byte transmitted in slave mode, ACK received<br>0xC0: Data byte transmitted in slave mode, ACK not received<br>0xC8: The Last byte transmitted in slave mode, ACK received<br>0xD0: Second Address byte + Write bit transmitted, ACK received |

| Offset: 0x0010 |            |             | Register Name: TWI_STAT                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
|                |            |             | 0xD8: Second Address byte + Write bit transmitted, ACK not received<br>0xF8: No relevant status information, INT_FLAG=0<br>Others: Reserved |

#### 9.1.6.6 0x0014 TWI Clock Register (Default Value: 0x0000\_0080)

| Offset: 0x0014 |            |             | Register Name: TWI_CCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7              | R/W        | 0x1         | <b>CLK_DUTY</b><br>Setting duty cycle of clock as master<br>0: 50%<br>1: 40%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6:3            | R/W        | 0x0         | <b>CLK_M</b><br>The TWI SCL output frequency, in master mode, is F1/10:<br>$F1 = F0/(CLK\_M + 1)$<br>$F_{SCL} = F1/10 = Fin/(2^{CLK\_N} * (CLK\_M + 1)*10)$<br>Specially, $F_{SCL} = F1/11$ when $CLK\_M=0$ and $CLK\_DUTY=40\%$ due to the delay of SCL sample debounce.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2:0            | R/W        | 0x0         | <b>CLK_N</b><br>The TWI bus is sampled by the TWI at the frequency defined by F0:<br>$F_{SAMP} = F0 = Fin/2^{CLK\_N}$<br>The TWI SCL output frequency, in master mode, is F1/10:<br>$F1 = F0/(CLK\_M + 1)$<br>$F_{SCL} = F1/10 = Fin/(2^{CLK\_N} * (CLK\_M + 1)*10)$<br>Specially, $F_{SCL} = F1/11$ when $CLK\_M=0$ and $CLK\_DUTY=40\%$ due to the delay of SCL sample debounce.<br>For Example:<br>Fin = 24 MHz (APB clock input)<br>For 400 kHz full speed 2-wire, $CLK\_N = 1$ , $CLK\_M = 2$<br>$F0 = 24 \text{ MHz}/2^1 = 12 \text{ MHz}$ , $F1 = F0/(10*(2+1)) = 0.4 \text{ MHz}$<br>For 100 kHz standard speed 2-wire, $CLK\_N = 1$ , $CLK\_M = 11$<br>$F0 = 24 \text{ MHz}/2^1 = 12 \text{ MHz}$ , $F1 = F0/(10*(11+1)) = 0.1 \text{ MHz}$ |

#### 9.1.6.7 0x0018 TWI Soft Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: TWI_SRST                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31:1           | /          | /           | /                                                                                                                       |
| 0              | R/WAC      | 0x0         | SOFT_RST<br>Soft Reset<br>Write '1' to this bit to reset the TWI and clear to '0' when completing Soft Reset operation. |

#### 9.1.6.8 0x001C TWI Enhance Feature Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: TWI_EFR                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                                                                               |
| 1:0            | R/W        | 0x0         | DBN<br>Data Byte Number Follow Read Command Control<br>00: No data byte can be written after the read command<br>01: Only 1-byte data can be written after the read command<br>10: 2-bytes data can be written after the read command<br>11: 3-bytes data can be written after the read command |

#### 9.1.6.9 0x0020 TWI Line Control Register (Default Value: 0x0000\_003A)

| Offset: 0x0020 |            |             | Register Name: TWI_LCR                                     |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 31:6           | /          | /           | /                                                          |
| 5              | R          | 0x1         | SCL_STATE<br>Current State of TWI_SCL<br>0: Low<br>1: High |
| 4              | R          | 0x1         | SDA_STATE<br>Current State of TWI_SDA<br>0: Low<br>1: High |

| Offset: 0x0020 |            |             | Register Name: TWI_LCR                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 3              | R/W        | 0x1         | <p>SCL_CTL<br/>TWI_SCL Line State Control Bit<br/>When the line control mode is enabled (bit[2] is set), this bit decides the output level of TWI_SCL.<br/>0: Output low level<br/>1: Output high level</p>                   |
| 2              | R/W        | 0x0         | <p>SCL_CTL_EN<br/>TWI_SCL Line State Control Enable<br/>When this bit is set, the state of TWI_SCL is controlled by the value of bit[3].<br/>0: Disable TWI_SCL line control mode<br/>1: Enable TWI_SCL line control mode</p> |
| 1              | R/W        | 0x1         | <p>SDA_CTL<br/>TWI_SDA Line State Control Bit<br/>When the line control mode is enabled (bit[0] is set), this bit decides the output level of TWI_SDA.<br/>0: Output low level<br/>1: Output high level</p>                   |
| 0              | R/W        | 0x0         | <p>SDA_CTL_EN<br/>TWI_SDA Line State Control Enable<br/>When this bit is set, the state of TWI_SDA is controlled by the value of bit[1].<br/>0: Disable TWI_SDA line control mode<br/>1: Enable TWI_SDA line control mode</p> |

### 9.1.6.10 0x0200 TWI\_DRV Control Register (Default Value: 0x00F8\_1000)

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                     |
| 31             | R/WAC      | 0x0         | START_TRAN<br>Start transmission<br>0: Transmission idle<br>1: Start transmission<br>Automatically cleared to '0' when finished. If the slave is not responding for the expected status over the time defined by TIMEOUT, the current transmission will stop. All setting formats and data will be loaded from registers and FIFO when the transmission starts. |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                               |
| 29             | R/W        | 0x0         | RESTART_MODE<br>Restart mode<br>0: RESTART<br>1: STOP+START<br>Define the TWI_DRV action after sending the register address.                                                                                                                                                                                                                                    |
| 28             | R/W        | 0x0         | READ_TRAN_MODE<br>Read transition mode<br>0: Send slave_id+W<br>1: Not send slave_id+W<br>Setting this bit to '1' if reading from a slave in which the register width is equal to 0.                                                                                                                                                                            |
| 27:24          | R          | 0x0         | TRAN_RESULT<br>Transition result<br>000: OK<br>001: FAIL<br>Other: Reserved                                                                                                                                                                                                                                                                                     |

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 23:16          | R          | 0xf8        | <p>TWI_STA</p> <p>TWI status</p> <p>0x00: bus error</p> <p>0x08: START condition transmitted</p> <p>0x10: Repeated START condition transmitted</p> <p>0x18: Address + Write bit transmitted, ACK received</p> <p>0x20: Address + Write bit transmitted, ACK not received</p> <p>0x28: Data byte transmitted in master mode, ACK received</p> <p>0x30: Data byte transmitted in master mode, ACK not received</p> <p>0x38: Arbitration lost in address or data byte</p> <p>0x40: Address + Read bit transmitted, ACK received</p> <p>0x48: Address + Read bit transmitted, ACK not received</p> <p>0x50: Data byte received in master mode, ACK received</p> <p>0x58: Data byte received in master mode, ACK not received</p> <p>0x01: Timeout when sending the 9<sup>th</sup> SCL clock</p> <p>Other: Reserved</p> |
| 15:8           | R/W        | 0x10        | <p>TIMEOUT_N</p> <p>Timeout number</p> <p>When sending the 9<sup>th</sup> clock, assert fail signal when the slave device does not respond after <math>N \cdot F_{SCL}</math> cycles. And the software must do a reset to the TWI_DRV module and send a stop condition to slave.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1              | R/W        | 0x0         | <p>SOFT_RESET</p> <p>Software reset</p> <p>0: Normal</p> <p>1: Reset</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0              | R/W        | 0x0         | <p>TWI_DRV_EN</p> <p>TWI driver enable</p> <p>0: Module disable</p> <p>1: Module enable (only use in TWI Master Mode)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

### 9.1.6.11 0x0204 TWI\_DRV Transmission Configuration Register (Default Value: 0x0000\_0001)

| Offset: 0x0204 |            |             | Register Name: TWI_DRV_CFG                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:16          | R/W        | 0x0         | PKT_INTERVAL<br>Define the interval between each packet for PKT_INTERVAL F <sub>SCL</sub> cycles. |
| 15:0           | R/W        | 0x1         | PACKET_CNT<br>The FIFO data is transmitted as PACKET_CNT packets in current format.               |

### 9.1.6.12 0x0208 TWI\_DRV Slave ID Register (Default Value: 0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: TWI_DRV_SLV                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                                    |
| 15:9           | R/W        | 0x0         | SLV_ID<br>Slave device ID<br>For 7-bit addressing, the bit[7:1] indicates:<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0<br>For 10-bit addressing, the bit[7:1] indicates:<br>1, 1, 1, 1, 0, SLAX[9:8] |
| 8              | R/W        | 0x0         | CMD<br>R/W operation to slave device<br>0: Write<br>1: Read                                                                                                                                          |
| 7:0            | R/W        | 0x0         | SLV_ID_X<br>SLAX[7:0]<br>The low 8 bits for slave device ID with 10-bit addressing.                                                                                                                  |

### 9.1.6.13 0x020C TWI\_DRV Packet Format Register (Default Value: 0x0001\_0001)

| Offset: 0x020C |            |             | Register Name: TWI_DRV_FMT |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:24          | /          | /           | /                          |

| Offset: 0x020C |            |             | Register Name: TWI_DRV_FMT                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 23:16          | R/W        | 0x1         | ADDR_BYTE<br>How many bytes be sent as slave device reg address<br>0~255 |
| 15:0           | R/W        | 0x1         | DATA_BYTE<br>How many bytes be sent/received as data<br>1~65535          |

#### 9.1.6.14 0x0210 TWI\_DRV Bus Control Register (Default Value: 0x0000\_80C0)

| Offset: 0x0210 |            |             | Register Name: TWI_DRV_BUS_CTRL                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:17          | /          | /           | /                                                                                                                                                                              |
| 16             | W          | 0x0         | CLK_COUNT_MODE<br>Clock count mode<br>0: scl clock high period count on oscl<br>1: scl clock high period count on iscl                                                         |
| 15             | R/W        | 0x1         | CLK_DUTY<br>Setting duty cycle of clock as Master<br>0: 50%<br>1: 40%                                                                                                          |
| 14:12          | R/W        | 0x0         | CLK_N<br>TWI_DRV bus sampling clock F0=24MHz/2^CLK_N                                                                                                                           |
| 11:8           | R/W        | 0x0         | CLK_M<br>TWI_DRV output SCL frequency is $F_{SCL}=F1/10=(F0/(CLK\_M+1))/10$<br>Specially, Foscl = F1/11 when CLK_M=0 and CLK_DUTY=40% due to the delay of SCL sample debounce. |
| 7              | R          | 0x1         | SCL_STA<br>SCL current status                                                                                                                                                  |
| 6              | R          | 0x1         | SDA_STA<br>SDA current status                                                                                                                                                  |
| 5:4            | /          | /           | /                                                                                                                                                                              |
| 3              | R/W        | 0x0         | SCL_MOV<br>SCL manual output value                                                                                                                                             |

| Offset: 0x0210 |            |             | Register Name: TWI_DRV_BUS_CTRL     |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 2              | R/W        | 0x0         | SDA_MOV<br>SDA manual output value  |
| 1              | R/W        | 0x0         | SCL_MOE<br>SCL manual output enable |
| 0              | R/W        | 0x0         | SDA_MOE<br>SDA manual output enable |

#### 9.1.6.15 0x0214 TWI\_DRV Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: TWI_DRV_INT_CTRL                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:18          | /          | /           | /                                                                                       |
| 19             | R/W        | 0x0         | RX_REQ_INT_EN<br>If set, an interrupt is sent when RX_REQ_PD sets.                      |
| 18             | R/W        | 0x0         | TX_REQ_INT_EN<br>If set, an interrupt is sent when TX_REQ_PD sets.                      |
| 17             | R/W        | 0x0         | TRAN_ERR_INT_EN<br>If set, an interrupt is sent when TRAN_ERR_PD sets.                  |
| 16             | R/W        | 0x0         | TRAN_COM_INT_EN<br>If set, an interrupt is sent when TRAN_COM_PD sets.                  |
| 15:4           | /          | /           | /                                                                                       |
| 3              | R/W1C      | 0x0         | RX_REQ_PD<br>Set when the data byte number in RECV_FIFO reaches RX_TRIG.                |
| 2              | R/W1C      | 0x0         | TX_REQ_PD<br>Set when there is no less than DMA_TX_TRIG empty byte number in SEND_FIFO. |
| 1              | R/W1C      | 0x0         | TRAN_ERR_PD<br>Packet transmission failure pending                                      |
| 0              | R/W1C      | 0x0         | TRAN_COM_PD<br>Packet transmission completion pending                                   |

### 9.1.6.16 0x0218 TWI\_DRV DMA Configure Register (Default Value: 0x0010\_0010)

| Offset: 0x0218 |            |             | Register Name: TWI_DRV_DMA_CFG                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                               |
| 24             | R/W        | 0x0         | DMA_RX_EN<br>DMA RX Enable                                                                                                                                                                                                                                      |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                               |
| 21:16          | R/W        | 0x10        | RX_TRIGGER<br>RX trigger<br>When DMA_RX_EN is set, send DMA RX Req when the data byte number in RECV_FIFO reaches RX_TRIGGER, or the read transmission is completed, the data of RECV_FIFO does not reach RX_TRIGGER but as long as the RECV_FIFO is not empty. |
| 15:9           | /          | /           | /                                                                                                                                                                                                                                                               |
| 8              | R/W        | 0x0         | DMA_TX_EN<br>DMA TX Enable                                                                                                                                                                                                                                      |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                               |
| 5:0            | R/W        | 0x10        | TX_TRIGGER<br>TX trigger<br>When DMA_TX_EN is set, send DMA TX Req when the space of SEND_FIFO (FIFO Level - data volume) reaches TX_TRIGGER.                                                                                                                   |

### 9.1.6.17 0x021C TWI\_DRV FIFO Content Register (Default Value: 0x0000\_0000)

| Offset: 0x021C |            |             | Register Name: TWI_DRV_FIFO_CON                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:23          | /          | /           | /                                                                                                  |
| 22             | R/WAC      | 0x0         | RECV_FIFO_CLEAR<br>Set this bit to clear RECV_FIFO pointer, and this bit is cleared automatically. |
| 21:16          | R          | 0x0         | RECV_FIFO_CONTENT<br>The number of data in RECV_FIFO                                               |
| 15:7           | /          | /           | /                                                                                                  |
| 6              | R/WAC      | 0x0         | SEND_FIFO_CLEAR<br>Set this bit to clear SEND_FIFO pointer, and this bit is cleared automatically. |

| Offset: 0x021C |            |             | Register Name: TWI_DRV_FIFO_CON                      |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 5:0            | R          | 0x0         | SEND_FIFO_CONTENT<br>The number of data in SEND_FIFO |

#### 9.1.6.18 0x0300 TWI\_DRV Send Data FIFO Access Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: TWI_DRV_SEND_FIFO_ACC                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31:8           | /          | /           | /                                                                                                             |
| 7:0            | W          | 0x0         | SEND_DATA_FIFO<br>Address of a 32x8 SEND_FIFO, which stores reg address and data sending to the slave device. |

#### 9.1.6.19 0x0304 TWI\_DRV Receive Data FIFO Access Register (Default Value: 0x0000\_0000)

| Offset: 0x0304 |            |             | Register Name: TWI_DRV_RECV_FIFO_ACC                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:8           | /          | /           | /                                                                                                |
| 7:0            | R          | 0x0         | RECV_DATA_FIFO<br>Address of a 32x8 RECV_FIFO, which stores data received from the slave device. |

## 9.2 UART

### 9.2.1 Overview

The universal asynchronous receiver transmitter (UART) provides an asynchronous serial communication with external devices, modem (data carrier equipment, DCE). It performs serial-to-parallel conversion on the data received from peripherals and transmits the converted data to the internal bus. It also performs parallel-to-serial conversion on the data that is transmitted to peripherals.

The UART has the following features:

- Compatible with industry-standard 16450/16550 UARTs
- Supports IrDA-compatible slow infrared (SIR) format
- Two separate FIFOs: one is RX FIFO, and the other is TX FIFO
  - Each of them is 64 bytes (For UART0)
  - Each of them is 256 bytes (For UART1, UART2, UART3, UART4, and UART5)
- The working reference clock is from the APB bus clock
  - Speed up to 4 Mbit/s with 64 MHz APB clock
  - Speed up to 1.5 Mbit/s with 24 MHz APB clock
- 5 to 8 data bits for RS-232 characters, or 9 bits RS-485 format
- 1, 1.5 or 2 stop bits
- Programmable parity (even, odd, or no parity)
- Supports TX/RX DMA slave controller interface
- Supports software/hardware flow control
- Supports RX DMA Master interface (Only for UART1)
- Supports auto-flow by using CTS & RTS (Only for UART1/2/3)

### 9.2.2 Block Diagram

Figure 9-9 shows a block diagram of the UART.

Figure 9-9 UART Block Diagram



### 9.2.3 Functional Description

#### 9.2.3.1 External Signals

The following table describes the external signals of UART.

Table 9-4 UART External Signals

| Signal    | Description                | Type |
|-----------|----------------------------|------|
| UART0-TX  | UART0 Data Transmit        | O    |
| UART0-RX  | UART0 Data Receive         | I    |
| UART1-TX  | UART1 Data Transmit        | O    |
| UART1-RX  | UART1 Data Receive         | I    |
| UART1-CTS | UART1 Data Clear to Send   | I    |
| UART1-RTS | UART1 Data Request to Send | O    |
| UART2-TX  | UART2 Data Transmit        | O    |
| UART2-RX  | UART2 Data Receive         | I    |
| UART2-CTS | UART2 Data Clear to Send   | I    |
| UART2-RTS | UART2 Data Request to Send | O    |
| UART3-TX  | UART3 Data Transmit        | O    |
| UART3-RX  | UART3 Data Receive         | I    |

| Signal    | Description                | Type |
|-----------|----------------------------|------|
| UART3-CTS | UART3 Data Clear to Send   | I    |
| UART3-RTS | UART3 Data Request to Send | O    |
| UART4-TX  | UART4 Data Transmit        | O    |
| UART4-RX  | UART4 Data Receive         | I    |
| UART5-TX  | UART5 Data Transmit        | O    |
| UART5-RX  | UART5 Data Receive         | I    |

### 9.2.3.2 Clock Sources

The following table describes the clock sources of UART.

Table 9-5 UART Clock Sources

| Clock Sources | Description                                          |
|---------------|------------------------------------------------------|
| APB1 Bus      | UART clock source. Refer to CCU for details on APB1. |

### 9.2.3.3 Typical Applications and Timing Diagram

#### UART Serial Data Format

The following figure shows the UART serial data format. The start bit, data bit, parity bit, and stop bit can be configured.

Figure 9-10 UART Serial Data Format



#### Using UART for RTS/CTS Autoflow Control

Figure 9-11 shows the typical application diagram for RTS/CTS autoflow control. Figure 9-12 shows the data format of the RTS/CTS autoflow control.

**Figure 9-11 Application Diagram for RTS/CTS Autoflow Control****Figure 9-12 RTS/CTS Autoflow Control Data Format**

### Using UART for Serial IrDA

Figure 9-13 shows the application diagram for the IrDA transceiver. Figure 9-14 shows the data format of the serial IrDA.

**Figure 9-13 Application Diagram for IrDA Transceiver**

**Figure 9-14 Serial IrDA Data Format**

### Using UART for RS-485

Figure 9-15 shows the application diagram for the RS-485 transceiver. Figure 9-16 shows the data format of the RS-485.

**Figure 9-15 Application Diagram for RS-485 Transceiver****Figure 9-16 RS-485 Data Format**

#### 9.2.3.4 UART Operating Mode

##### Data Frame Format

The [UART\\_LCR](#) register can set the basic parameter of a data frame: data width (5 to 8 bits), stop bit number (1/1.5/2), parity type.

A frame transfer of the UART includes the start signal, data signal, parity bit, and stop signal. The LSB is transmitted first.

- Start signal (start bit): It is the start flag of a data frame. According to the UART protocol, the low level of the TXD signal indicates the start of a data frame. When the UART transmits data, the level needs to hold high.
- Data signal (data bit): The data bit width can be configured as 5-bit, 6-bit, 7-bit, and 8-bit through different applications.
- Parity bit: It is a 1-bit error correction signal. Parity bit includes odd parity, even parity. The UART can enable and disable the parity bit by setting the [UART\\_LCR](#) register.
- Stop Signal (stop bit): It is the stop bit of a data frame. The stop bit can be set to 1-bit, 1.5-bit, and 2-bit by the [UART\\_LCR](#) register. The high level of the TXD signal indicates the end of a data frame.

### Baud and Error Rates

The baud rate is calculated as follows: Baud rate = SCLK/(16 \* divisor).

The SCLK is usually APB1 and can be set in section 3.3 “[CCU](#)”.

The divisor is frequency divider of UART. The frequency divider has 16-bit, the low 8-bit is in the [UART\\_DLL](#) register, the high 8-bit is in the [UART\\_DLH](#) register.

The relationship between the different UART mode and the error rate is as follows.

**Figure 9-17 UART Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Over sampling | Error (%) |
|--------------|---------|-----------|---------------|-----------|
| 24000000     | 5000    | 300       | 16            | 0         |
| 24000000     | 2500    | 600       | 16            | 0         |
| 24000000     | 1250    | 1200      | 16            | 0         |
| 24000000     | 625     | 2400      | 16            | 0         |
| 24000000     | 313     | 4800      | 16            | -0.16     |
| 24000000     | 156     | 9600      | 16            | 0.16      |
| 24000000     | 78      | 19200     | 16            | 0.16      |
| 24000000     | 39      | 38400     | 16            | 0.16      |
| 24000000     | 26      | 57600     | 16            | 0.16      |
| 24000000     | 13      | 115200    | 16            | 0.16      |
| 48000000     | 13      | 230400    | 16            | 0.16      |
| 64000000     | 7       | 576000    | 16            | -0.794    |
| 75000000     | 5       | 921600    | 16            | 1.725     |

| Clock source | Divisor | Baud rate | Over sampling | Error (%) |
|--------------|---------|-----------|---------------|-----------|
| 48000000     | 3       | 1000000   | 16            | 0         |
| 24000000     | 1       | 1500000   | 16            | 0         |
| 48000000     | 1       | 3000000   | 16            | 0         |
| 64000000     | 1       | 4000000   | 16            | 0         |

Figure 9-18 IrDA Mode Baud and Error Rates

| Clock source | Divisor | Baud rate | Encoding | Error (%) |
|--------------|---------|-----------|----------|-----------|
| 24000000     | 5000    | 300       | 3/16     | 0         |
| 24000000     | 2500    | 600       | 3/16     | 0         |
| 24000000     | 1250    | 1200      | 3/16     | 0         |
| 24000000     | 625     | 2400      | 3/16     | 0         |
| 24000000     | 313     | 4800      | 3/16     | -0.16     |
| 24000000     | 156     | 9600      | 3/16     | 0.16      |
| 24000000     | 78      | 19200     | 3/16     | 0.16      |
| 24000000     | 39      | 38400     | 3/16     | 0.16      |
| 24000000     | 26      | 57600     | 3/16     | 0.16      |
| 24000000     | 13      | 115200    | 3/16     | 0.16      |

Figure 9-19 RS485 Mode Baud and Error Rates

| Clock source | Divisor | Baud rate | Encoding | Error (%) |
|--------------|---------|-----------|----------|-----------|
| 24000000     | 5000    | 300       | 16       | 0         |
| 24000000     | 2500    | 600       | 16       | 0         |
| 24000000     | 1250    | 1200      | 16       | 0         |
| 24000000     | 625     | 2400      | 16       | 0         |
| 24000000     | 313     | 4800      | 16       | -0.16     |
| 24000000     | 156     | 9600      | 16       | 0.16      |
| 24000000     | 78      | 19200     | 16       | 0.16      |
| 24000000     | 39      | 38400     | 16       | 0.16      |
| 24000000     | 26      | 57600     | 16       | 0.16      |
| 24000000     | 13      | 115200    | 16       | 0.16      |

### DLAB Definition

The DLAB control bit ([UART\\_LCR\[7\]](#)) is the access control bit of the divisor Latch register.

If DLAB is 0, then the 0x00 offset address is the [UART\\_RBR/UART\\_THR](#) (RX/TX FIFO) register, and the 0x04 offset address is the [UART\\_IER](#) register.

If DLAB is 1, then the 0x00 offset address is the [UART\\_DLL](#) register, and the 0x04 offset address is the [UART\\_DLH](#) register.

When the UART initializes, the divisor needs to be set. That is, writing 1 to DLAB can access the [UART\\_DLL](#) and [UART\\_DLH](#) register, after finished the configuration, writing 0 to DLAB can access the [UART\\_RBR/UART\\_THR](#) register.

### CHCFG\_AT\_BUSY Definition

The function of the CHCFG\_AT\_BUSY ([UART\\_HALT\[1\]](#)) and CHANGE\_UPDATE ([UART\\_HALT\[2\]](#)) are as follows.

**CHCFG\_AT\_BUSY:** Enable the bit, the software can also set the UART controller when UART is busy, such as the [UART\\_LCR](#), [UART\\_DLH](#), [UART\\_DLL](#) register.

**CHANGE\_UPDATE:** If CHCFG\_AT\_BUSY is enabled, and CHANGE\_UPDATE is written to 1, the configuration of the UART controller can be updated. After completed the update, the bit is cleared to 0 automatically.

Setting divisor performs the following steps:

**Step 1** Write 1 to CHCFG\_AT\_BUSY to enable “configure at busy”.

**Step 2** Write 1 to DLAB ([UART\\_LCR\[7\]](#)) and set the [UART\\_DLH](#) and [UART\\_DLL](#) registers.

**Step 3** Write 1 to CHANGE\_UPDATE to update the configuration. The bit is cleared to 0 automatically after completing the update.

### UART Busy Flag

The [UART\\_USR\[0\]](#) is a busy flag of the UART controller.

When the TX transmits data, or the RX receives data, or the TX FIFO is not empty, or the RX FIFO is not empty, then the busy flag bit can be set to 1 by hardware, which indicates the UART controller is busy.

#### 9.2.4 Programming Guidelines

The following takes the UART module in the CPUX domain as an example.

### 9.2.4.1 Initialization

#### Step 1 System Initialization

- Configure [APB1\\_CFG\\_REG](#) in the CCU module to set the APB1 bus clock (The clock is 24MHz by default).
- Set [UART\\_BGR\\_REG](#)[UARTx\_GATING] to 1 to enable the module clock, and set [UART\\_BGR\\_REG](#)[UARTx\_RST] to 1 to de-assert the module.

#### Step 2 UART Controller Initialization

- IO configuration: Configure GPIO multiplex as UART function, and set UART pins to internal pull-up mode (For detail, see the description in section 9.7 “[GPIO](#)”).
- Baud-rate configuration:
  - Set UART baud-rate (refer to section 9.2.3.4);
  - Write [UART\\_FCR](#)[FIFOE] to 1 to enable TX/RX FIFO;
  - Write [UART\\_HALT](#)[HALT\_TX] to 1 to disable TX transfer;
  - Set [UART\\_LCR](#)[DLAB] to 1, remain default configuration for other bits; set 0x00 offset address to the [UART\\_DLL](#) register, set 0x04 offset address to the [UART\\_DLH](#) register;
  - Write the high 8-bit of divisor to the [UART\\_DLH](#) register, and write the low 8-bit of divisor to the [UART\\_DLL](#) register;
  - Set [UART\\_LCR](#)[DLAB] to 0, remain default configuration for other bits; set 0x00 offset address to the [UART\\_RBR](#)/[UART\\_THR](#) register, set 0x04 offset address to the [UART\\_IER](#) register;
  - Set [UART\\_HALT](#)[HALT\_TX] to 0 to enable TX transfer.

#### Step 3 Controller Parameter Configuration

- Set data width, stop bits, and even/odd parity type by writing the [UART\\_LCR](#) register.
- Reset, enable FIFO and set FIFO trigger condition by writing the [UART\\_FCR](#) register.
- Set the flow control parameter by writing the [UART\\_MCR](#) register.

#### Step 4 Interrupt Configuration

- Configure UART interrupt vector number to request UART interrupt (Refer to section 3.8 “[GIC](#)” module for interrupt vector number).
- In DMA mode, write [UART\\_IER](#) to 0 to disable interrupt; write [UART\\_HSK](#)[Handshake configuration] to 0xE5 to set DMA handshake mode; write [UART\\_FCR](#)[DMAM] to 1 to set DMA transmission/reception mode; set DMA parameter and request DMA interrupt according to DMA configuration process.

- In Interrupt mode, configure **UART\_IER** to enable the corresponding interrupt according to requirements: such as transmit (TX) interrupt, receive (RX) interrupt, receive line status interrupt, RS48 interrupt, etc. (Here TX/RX interrupt is usually used).

#### 9.2.4.2 Transferring/Receiving Data in Query Mode

##### Data transfer

**Step 1** Write data to **UART\_THR** to start data transfer.

**Step 2** Check TX\_FIFO status by reading **UART\_USR**[TFNF]. If the bit is 1, data can continue to be written; if the bit is 0, wait for data transfer, and data cannot continue to write until FIFO is not full.

##### Data receive

**Step 1** Check RX\_FIFO status by reading **UART\_USR**[RFNE].

**Step 2** Read data from **UART\_RBR** if RX\_FIFO is not empty.

**Step 3** If **UART\_USR**[RFNE] is 0, data is received completely.

#### 9.2.4.3 Transferring/Receiving Data in Interrupt Mode

##### Data transfer

**Step 1** Set **UART\_IER**[ETBEI] to 1 to enable the *UART transmission interrupt*.

**Step 2** Write the data to be transmitted to **UART\_THR**.

**Step 3** When the data of TX\_FIFO meets trigger condition (such as FIFO/2, FIFO/4), the UART transfer interrupt is generated.

**Step 4** Check **UART\_USR**[TFE] and determine whether TX\_FIFO is empty. If **UART\_USR**[TFE] is 1, it indicates that the data in TX\_FIFO is transmitted completely.

**Step 5** Clear **UART\_IER**[ETBEI] to 0 to disable transfer interrupt.

##### Data receive

**Step 1** Set **UART\_IER**[ERBFI] to 1 to enable the *UART reception interrupt*.

**Step 2** When the received data from RX\_FIFO meets trigger condition (such as FIFO/2, FIFO/4), the UART receive interrupt is generated.

**Step 3** Read data from [UART\\_RBR](#).

**Step 4** Check RX\_FIFO status by reading [UART\\_USR](#)[RFNE] and determine whether to read data. If the bit is 1, continue to read data from [UART\\_RBR](#) until [UART\\_USR](#)[RFNE] is cleared to 0, which indicates data is received completely.

#### 9.2.4.4 Transferring/Receiving Data in DMA Mode

##### Data transfer

**Step 1** Configure the UART DMA interrupt according to the initialization process.

**Step 2** Configure DMA data channel, including the transfer source address, the transfer destination address, the number of data to be transferred, and the transfer type, and so on. (For details, see section 3.9 “[DMAC](#)”).

**Step 3** Enable the DMA transfer function of the UART by setting the register of the DMA module.

**Step 4** Determine whether UART data is transferred completely based on the DMA status. If all data is transferred completely, disable the DMA transfer function of the UART.

##### Data receive

**Step 1** Configure DMA data channel, including the transfer source address, the transfer destination address, the number of data to be transferred, and the transfer type, and so on. (For details, see section 3.9 “[DMAC](#)”).

**Step 2** Enable the DMA receive function of the UART by setting the register of the DMA module.

**Step 3** Determine whether UART data is received completely based on the DMA status. If all data is received completely, disable the DMA receive function of the UART.

#### 9.2.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| UART0       | 0x02500000   |
| UART1       | 0x02500400   |
| UART2       | 0x02500800   |
| UART3       | 0x02500C00   |
| UART4       | 0x02501000   |
| UART5       | 0x02501400   |

| Register Name       | Offset | Description                                   |
|---------------------|--------|-----------------------------------------------|
| UART_RBR            | 0x0000 | UART Receive Buffer Register                  |
| UART_THR            | 0x0000 | UART Transmit Holding Register                |
| UART_DLL            | 0x0000 | UART Divisor Latch Low Register               |
| UART_DLH            | 0x0004 | UART Divisor Latch High Register              |
| UART_IER            | 0x0004 | UART Interrupt Enable Register                |
| UART_IIR            | 0x0008 | UART Interrupt Identity Register              |
| UART_FCR            | 0x0008 | UART FIFO Control Register                    |
| UART_LCR            | 0x000C | UART Line Control Register                    |
| UART_MCR            | 0x0010 | UART Modem Control Register                   |
| UART_LSR            | 0x0014 | UART Line Status Register                     |
| UART_MSR            | 0x0018 | UART Modem Status Register                    |
| UART_SCH            | 0x001C | UART Scratch Register                         |
| UART_USR            | 0x007C | UART Status Register                          |
| UART_TFL            | 0x0080 | UART Transmit FIFO Level Register             |
| UART_RFL            | 0x0084 | UART Receive FIFO Level Register              |
| UART_HSK            | 0x0088 | UART DMA Handshake Configuration Register     |
| UART_DMA_REQ_EN     | 0x008C | UART DMA Request Enable Register              |
| UART_HALT           | 0x00A4 | UART Halt TX Register                         |
| UART_DBG_DLL        | 0x00B0 | UART Debug DLL Register                       |
| UART_DBG_DLH        | 0x00B4 | UART Debug DLH Register                       |
| UART_A_FCC          | 0x00F0 | UART FIFO Clock Control Register              |
| UART_A_RXDMA_CTRL   | 0x0100 | UART RXDMA Control Register                   |
| UART_A_RXDMA_STR    | 0x0104 | UART RXDMA Start Register                     |
| UART_A_RXDMA_STA    | 0x0108 | UART RXDMA Status Register                    |
| UART_A_RXDMA_LMT    | 0x010C | UART RXDMA Limit Register                     |
| UART_A_RXDMA_SADDRL | 0x0110 | UART RXDMA Buffer Start Address Low Register  |
| UART_A_RXDMA_SADDRH | 0x0114 | UART RXDMA Buffer Start Address High Register |
| UART_A_RXDMA_BL     | 0x0118 | UART RXDMA Buffer Length Register             |
| UART_A_RXDMA_IE     | 0x0120 | UART RXDMA Interrupt Enable Register          |
| UART_A_RXDMA_IS     | 0x0124 | UART RXDMA Interrupt Status Register          |
| UART_A_RXDMA_WADDRL | 0x0128 | UART RXDMA Write Address Low Register         |
| UART_A_RXDMA_WADDRH | 0x012C | UART RXDMA Write Address high Register        |

| Register Name       | Offset | Description                           |
|---------------------|--------|---------------------------------------|
| UART_A_RXDMA_RADDRL | 0x0130 | UART RXDMA Read Address Low Register  |
| UART_A_RXDMA_RADDRH | 0x0134 | UART RXDMA Read Address high Register |
| UART_A_RXDMA_DCNT   | 0x0138 | UART RADMA Data Count Register        |

## 9.2.6 Register Description

### 9.2.6.1 0x0000 UART Receiver Buffer Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_RBR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7:0            | R          | 0x0         | <p><b>RBR</b><br/> <b>Receiver Buffer Register</b><br/> Data byte received on the serial input port (sin) in UART mode, or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in <a href="#">UART_LCR</a> is set. If in FIFO mode and FIFOs are enabled (The <a href="#">UART_FCR</a>[0] is set to 1), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register can not read before the next data character arrives, then the data already in the FIFO are preserved, but any incoming data are lost and an overrun error occurs.</p> |

### 9.2.6.2 0x0000 UART Transmit Holding Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_THR |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:8           | /          | /           | /                       |

| Offset: 0x0000 |            |             | Register Name: UART_THR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0            | W          | 0x0         | <p>THR</p> <p>Transmit Holding Register</p> <p>Data is transmitted on the serial output port (SOUT) in UART mode or the serial infrared output (sir_out_n) in infrared mode.</p> <p>Data should only be written to the <a href="#">UART_THR</a> when the THRE bit (<a href="#">UART_LSR[5]</a>) is set.</p> <p>If in FIFO mode and FIFOs are enabled (<a href="#">UART_FCR[0]</a> = 1) and THRE is set, the 16 number of characters data may be written to the <a href="#">UART_THR</a> before the FIFO is full. When the FIFO is full, any written data results in the written data being lost.</p> |

#### 9.2.6.3 0x0000 UART Divisor Latch Low Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_DLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:0            | R/W        | 0x0         | <p>DLL</p> <p>Divisor Latch Low</p> <p>Lower 8 bits of 16 bits, read/write, Divisor Latch Register contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (<a href="#">UART_LCR[7]</a>) is set and the UART is not busy (<a href="#">UART_USR[0]</a> is 0).</p> <p>The output baud rate is equal to the serial clock (SCLK) frequency divided by sixteen times the value of the baud rate divisor, as follows: <b>baud rate = (serial clock freq)/(16 * divisor)</b>.</p> <p>Note that when the Divisor Latch Registers (<a href="#">UART_DLL</a> and <a href="#">UART_DLH</a>) are set to 0, the baud clock is disabled and no serial communications occur. Also, once the DLL is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 9.2.6.4 0x0004 UART Divisor Latch High Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_DLH |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:8           | /          | /           | /                       |

| Offset: 0x0004 |            |             | Register Name: UART_DLH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:0            | R/W        | 0x0         | <p>DLH<br/>Divisor Latch High<br/>Upper 8 bits of 16 bits, read/write, Divisor Latch Register contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (<a href="#">UART_LCR[7]</a>) is set and the UART is not busy (<a href="#">UART_USR[0]</a> is 0).<br/>The output baud rate is equal to the serial clock (SCLK) frequency divided by sixteen times the value of the baud rate divisor, as follows: <b>baud rate = (serial clock freq)/(16 * divisor)</b>.<br/>Note that when the Divisor Latch Registers (<a href="#">UART_DLL</a> and <a href="#">UART_DLH</a>) is set to 0, the baud clock is disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 9.2.6.5 0x0004 UART Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_IER                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                       |
| 7              | R/W        | 0x0         | <p>PTIME<br/>Programmable THRE Interrupt Mode Enable<br/>This is used to enable/disable the generation of THRE Interrupt.<br/>0: Disable<br/>1: Enable</p>                                              |
| 6:5            | /          | /           | /                                                                                                                                                                                                       |
| 4              | R/W        | 0x0         | <p>RS485_INT_EN<br/>RS485 Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                             |
| 3              | R/W        | 0x0         | <p>EDSSI<br/>Enable Modem Status Interrupt<br/>This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest priority interrupt.<br/>0: Disable<br/>1: Enable</p> |

| Offset: 0x0004 |            |             | Register Name: UART_IER                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                             |
| 2              | R/W        | 0x0         | <p>ELSI<br/>Enable Receiver Line Status Interrupt<br/>This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt.<br/>0: Disable<br/>1: Enable</p>                                                                                         |
| 1              | R/W        | 0x0         | <p>ETBEI<br/>Enable Transmit Holding Register Empty Interrupt<br/>This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third-highest priority interrupt.<br/>0: Disable<br/>1: Enable</p>                                                         |
| 0              | R/W        | 0x0         | <p>ERBFI<br/>Enable Received Data Available Interrupt<br/>This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFOs enabled). These are the second-highest priority interrupt.<br/>0: Disable<br/>1: Enable</p> |

#### 9.2.6.6 0x0008 UART Interrupt Identity Register (Default Value: 0x0000\_0001)

| Offset: 0x0008 |            |             | Register Name: UART_IIR                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:8           | /          | /           | /                                                                                                                                          |
| 7:6            | R          | 0x0         | <p>FEFLAG<br/>FIFOs Enable Flag<br/>This is used to indicate whether the FIFOs are enabled or disabled.<br/>00: Disable<br/>11: Enable</p> |
| 5:4            | /          | /           | /                                                                                                                                          |

| Offset: 0x0008 |            |             | Register Name: UART_IIR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:0            | R          | 0x1         | <p>IID<br/>Interrupt ID<br/>This indicates the highest priority pending interrupt which can be one of the following types.</p> <ul style="list-style-type: none"> <li>0000: modem status</li> <li>0001: no interrupt pending</li> <li>0010: THR empty</li> <li>0011: RS485 Interrupt</li> <li>0100: received data available</li> <li>0110: receiver line status</li> <li>0111: busy detect</li> <li>1100: character timeout</li> </ul> <p>The bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt.</p> |

| Interrupt ID | Priority Level | Interrupt Type               | Interrupt Source                                                                                                                   | Interrupt Reset                                                                                                                                |
|--------------|----------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0001         | Lowest         | None                         | None                                                                                                                               | -                                                                                                                                              |
| 0110         | Highest        | Receiver line status         | Overrun/parity/framing errors or break interrupt                                                                                   | Reading the line status register                                                                                                               |
| 0011         | Second         | RS485 Interrupt              | In RS485 mode, receives address data and match setting address                                                                     | Writes 1 to addr flag to reset                                                                                                                 |
| 0100         | Third          | Received data available      | Receiver data available (non-FIFO mode or FIFOs disabled) or RCVR FIFO trigger level reached (FIFO mode and FIFOs enabled)         | Reading the receiver buffer register (non-FIFO mode or FIFOs disabled) or the FIFO drops below the trigger level (FIFO mode and FIFOs enabled) |
| 1100         | Fourth         | Character timeout indication | No characters in or out of the RCVR FIFO during the last 4 character times and there is at least 1character in it during This time | Reading the receiver buffer register                                                                                                           |

| Interrupt ID | Priority Level | Interrupt Type                  | Interrupt Source                                                                                                                                                                              | Interrupt Reset                                                                                                                                                                                    |
|--------------|----------------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0010         | Fifth          | Transmit holding register empty | Transmitter holding register empty (Program THRE mode disabled) or XMIT FIFO at or below threshold (Program THRE mode enabled)                                                                | Reading the IIR register (if the source of interrupt); or, writing into THR (FIFOs or THRE mode not selected or disabled) or XMIT FIFO above threshold (FIFOs and THRE mode selected and enabled). |
| 0000         | Sixth          | Modem status                    | Clear to send or data set ready or ring indicator or data carrier detect. Note that if the autoflow control mode is enabled, a change in CTS (that is, DCTS set) does not cause an interrupt. | Reading the Modem status register                                                                                                                                                                  |
| 0111         | Seventh        | Busy detect indication          | UART_16550_COMPATIBLE = NO and master has tried to write to the Line Control Register while the UART is busy (USR[0] is set to one).                                                          | Reading the UART status register                                                                                                                                                                   |

#### 9.2.6.7 0x0008 UART FIFO Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7:6            | W          | 0x0         | <p>RT<br/>RCVR Trigger</p> <p>This is used to select the trigger level in the receiver FIFO when the Received Data Available Interrupt is generated. In the autoflow control mode, it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation.</p> <p>00: 1 character in the FIFO<br/>01: FIFO ¼ full<br/>10: FIFO ½ full<br/>11: FIFO-2 less than full</p> |

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5:4            | W          | 0x0         | <p>TFT</p> <p>TX Empty Trigger</p> <p>This is used to select the empty threshold level when the THRE Interrupts are generated and the mode is active. It also determines when the dma_tx_req_n signal is asserted in certain modes of operation.</p> <ul style="list-style-type: none"> <li>00: FIFO empty</li> <li>01: 2 characters in the FIFO</li> <li>10: FIFO ¼ full</li> <li>11: FIFO ½ full</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3              | W          | 0x0         | <p>DMAM</p> <p>DMA Mode</p> <p>0: Mode 0</p> <p>In this mode, when the PTE in UART_HALT is high and TX FIFO is enabled, the TX DMA request will be set when the TFL in UART_TFL is less than or equal to FIFO Trigger Level (otherwise it will be cleared). When the PTE is high and TX FIFO is disabled, the TX DMA request will be set only if the THR in UART_THR is empty. If the PTE is low, the TX DMA request will be set only if the TX FIFO (TX FIFO enabled) or THR (TX FIFO disabled) is empty.</p> <p>When the DMA_PTE_RX in UART_HALT is high and RX FIFO is enabled, the RX DRQ will be set only if the RFL in UART_RFL is equal to or more than FIFO Trigger Level, otherwise, it will be cleared.</p> <p>1: Mode 1</p> <p>In this mode, TX FIFO should be enabled. If the PTE in <a href="#">UART_HALT</a> is high, the TX DMA request will be set when the TFL in <a href="#">UART_TFL</a> is less than or equal to FIFO Trigger Level; If the PTE is low, the TX DMA request will be set when TX FIFO is empty. Once the request is set, it is cleared only when TX FIFO is full.</p> <p>If the RFL in UART_RFL is equal to or more than FIFO Trigger Level or there is a character timeout, the RX DRQ will be set; Once the RX DRQ is set, it is cleared only when RX FIFO (RX FIFO enabled) or RBR (RX FIFO disabled) is empty.</p> |
| 2              | W          | 0x0         | <p>XFIFOR</p> <p>XMIT FIFO Reset</p> <p>The bit resets the control part of the transfer FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request.</p> <p>It is 'self-cleared'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 1              | W          | 0x0         | <p>RFIFOR<br/>RCVR FIFO Reset<br/>The bit resets the control part of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request.<br/>It is 'self-cleared'. It is not necessary to clear this bit.</p> |
| 0              | W          | 0x0         | <p>FIFOE<br/>Enable FIFOs<br/>The bit enables/disables the transmitting (XMIT) and receiving (RCVR) FIFOs. Whenever the value of this bit is changed, both the XMIT and RCVR controller part of FIFOs is reset.</p>               |

#### 9.2.6.8 0x000C UART Line Control Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7              | R/W        | 0x0         | <p>DLAB<br/>Divisor Latch Access Bit<br/>It is writable only when UART is not busy (UART_USR[0] is 0) and always readable. This bit is used to enable the reading and writing of the Divisor Latch register (UART_DLL and UART_DLH) to set the baud rate of the UART. This bit must be cleared after the initial baud rate setup in order to access other registers.<br/>0: Select RX Buffer Register (UART_RBR)/TX Holding Register (UART_THR) and Interrupt Enable Register (UART_IER)<br/>1: Select Divisor Latch LS Register (UART_DLL) and Divisor Latch MS Register (UART_DLM)</p> |
| 6              | R/W        | 0x0         | <p>BC<br/>Break Control Bit<br/>This is used to cause a break condition to be transmitted to the receiving device. If set to 0, the serial output is forced to the spacing (logic 0) state. When not in Loopback mode, as determined by UART_MCR[4], the SOUT line is forced low until the Break bit is cleared. If SIR_MODE is enabled and active (UART_MCR[6] is set to 1), the sir_out_n line is continuously pulsed. When in Loopback mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low.</p>                                  |

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5:4            | R/W        | 0x0         | <p>EPS<br/>Even Parity Select</p> <p>It is writable only when UART is not busy (UART_USR[0] is 0). This is used to select the even and odd parity when the PEN is enabled (the UART_LCR[3] is set to 1). Setting the UART_LCR[5] is unset to reverse the LCR[4].</p> <p>00: Odd Parity<br/>01: Even Parity<br/>1X: Reverse LCR[4]</p> <p>In RS485 mode, it is the 9th bit--address bit.</p> <p>11: 9th bit = 0, indicates that this is a data byte.<br/>10: 9th bit = 1, indicates that this is an address byte.</p> <p><b>Note: When using this function, the PEN(UART_LCR[3]) must set to 1.</b></p>                                             |
| 3              | R/W        | 0x0         | <p>PEN<br/>Parity Enable</p> <p>It is writable only when UART is not busy (UART_USR[0] is 0) and always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial characters respectively.</p> <p>0: Parity disabled<br/>1: Parity enabled</p>                                                                                                                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x0         | <p>STOP<br/>Number of stop bits</p> <p>It is writable only when UART is not busy (UART_USR[0] is 0) and always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to 0, one stop bit is transmitted in the serial data. If set to 1 and the data bits are set to 5 (UART_LCR[1:0] is 0), one and a half stop bit is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.</p> <p>0: 1 stop bit<br/>1: 1.5 stop bits when DLS(LCR[1:0]) is zero, else 2 stop bit</p> |

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                            |
| 1:0            | R/W        | 0x0         | <p>DLS<br/>Data Length Select</p> <p>It is writable only when UART is not busy (UART_USR[0] is 0) and always readable. This is used to select the count of bits in a transmitted or received frame.</p> <p>00: 5 bits<br/>01: 6 bits<br/>10: 7 bits<br/>11: 8 bits</p> |

#### 9.2.6.9 0x0010 UART Modem Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 31:8           | /          | /           | /                                                                                                                                                                                                                |
| 7:6            | R/W        | 0x0         | <p>UART_FUNCTION<br/>Select IrDA or RS485</p> <p>00: UART Mode<br/>01: IrDA SIR Mode<br/>10: RS485 Mode<br/>11: Reserved</p>                                                                                     |
| 5              | R/W        | 0x0         | <p>AFCE<br/>Auto Flow Control Enable</p> <p>When FIFOs are enabled and the AFCE bit is set, the AutoFlow Control is enabled.</p> <p>0: Auto Flow Control mode disabled<br/>1: Auto Flow Control mode enabled</p> |

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4              | R/W        | 0x0         | <p>LOOP</p> <p>Loop Back Mode</p> <p>0: Normal Mode</p> <p>1: Loop Back Mode</p> <p>This is used to put the UART into a diagnostic mode for test purposes. If operating in UART mode (SIR_MODE != Enabled or not active, UART_MCR[6] is set to 0), the data on the SOUT line is held high, while serial data output is looped back to the sin line, internally. In this mode, all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally. If operating in infrared mode (SIR_MODE == Enabled AND active, UART_MCR[6] is set to 1), the data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.</p>                                                                                                                                 |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1              | R/W        | 0x0         | <p>RTS</p> <p>Request to Send</p> <p>This is used to directly control the Request to Send (rts_n) output. The RTS (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (UART_MCR[5] is set to 0), the rts_n signal is set low by programming UART_MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (UART_MCR[5] is set to 1) and FIFOs enable (UART_FCR[0] is set to 1), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when UART_MCR[1] is set low.</p> <p>0: rts_n de-asserted (logic 1)</p> <p>1: rts_n asserted (logic 0)</p> <p>Note that in Loopback mode (UART_MCR[4] is set to 1), the rts_n output is held inactive high while the value of this location is internally looped back to an input.</p> |

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0              | R/W        | 0x0         | <p>DTR<br/>Data Terminal Ready</p> <p>This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n.</p> <p>0: dtr_n de-asserted (logic 1)<br/>1: dtr_n asserted (logic 0)</p> <p>The DTR output is used to inform the modem or data set that the UART is ready to establish communications.</p> <p>Note that in Loopback mode (UART_MCR[4] is set to 1), the dtr_n output is held inactive high while the value of this location is internally looped back to an input.</p> |

#### 9.2.6.10 0x0014 UART Line Status Register (Default Value: 0x0000\_0060)

| Offset:0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                       |
| 31:8          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                 |
| 7             | R          | 0x0         | <p>FIFOERR<br/>RX Data Error in FIFO</p> <p>When FIFOs are disabled, this bit is always 0. When FIFOs are enabled, this bit is set to "1" when there is at least one PE, FE, or BI in the RX FIFO. It is cleared by reading from the UART_LSR register, there are no subsequent errors in the FIFO.</p>                                                           |
| 6             | R          | 0x1         | <p>TEMT<br/>Transmitter Empty</p> <p>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register (UART_THR) and the TX Shift Register are empty. If the FIFOs are enabled, this bit is set whenever the TX FIFO and the TX Shift Register are empty. In both cases, this bit is cleared when a byte is written to the TX data channel.</p> |

| Offset:0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5             | R          | 0x1         | <p>THRE<br/>TX Holding Register Empty</p> <p>If the FIFOs are disabled, this bit is set to "1" when the TX Holding Register (UART_THR) is empty and ready to accept new data and it is cleared when the CPU writes to the TX Holding Register.</p> <p>If the FIFOs are enabled, this bit is set to "1" whenever the TX FIFO is empty and it is cleared when at least one byte is written to the TX FIFO.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4             | R          | 0x0         | <p>BI<br/>Break Interrupt</p> <p>This is used to indicate the detection of a break sequence on the serial input data.</p> <p>If in UART mode (SIR_MODE == Disabled), it is set when the serial input, sir_in, is held in a logic '0' state for longer than the sum of <i>start time + data bits + parity + stop bits</i>.</p> <p>If in infrared mode (SIR_MODE == Enabled), it is set when the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of <i>start time + data bits + parity + stop bits</i>. A break condition on serial input causes one and only one character, consisting of all zeros, to be received by the UART.</p> <p>In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO. Reading the UART_LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the UART_LSR is read.</p> |

| Offset:0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3             | RC         | 0x0         | <p>FE<br/>Framing Error</p> <p>This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.</p> <p>In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (UART_LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (UART_LSR[4]).</p> <p>0: no framing error<br/>1: framing error</p> <p>Reading the UART_LSR clears the FE bit.</p> |
| 2             | RC         | 0x0         | <p>PE<br/>Parity Error</p> <p>This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (UART_LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (UART_LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (UART_LSR[4]).</p> <p>0: no parity error<br/>1: parity error</p> <p>Reading the UART_LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                         |

| Offset:0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1             | RC         | 0x0         | <p>OE<br/>Overrun Error</p> <p>This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the UART_RBR. When this happens, the data in the UART_RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.</p> <p>0: no overrun error<br/>1: overrun error</p> <p>Reading the UART_LSR clears the OE bit.</p> |
| 0             | R          | 0x0         | <p>DR<br/>Data Ready</p> <p>This is used to indicate that the receiver contains at least one character in the UART_RBR or the receiver FIFO.</p> <p>0: no data ready<br/>1: data ready</p> <p>This bit is cleared when the UART_RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.</p> <p><b>Note: Not use when the RXDMA master is enabled (rxdma_ctrl[0] is set to 1).</b></p>                                                                                                                                                                                                                      |

#### 9.2.6.11 0x0018 UART Modem Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7              | R          | 0x0         | <p>DCD<br/>Line State of Data Carrier Detect</p> <p>This is used to indicate the current state of the modem control line dcd_n. This bit is the complement of dcd_n. When the Data Carrier Detect input (dcd_n) is asserted it is an indication that the carrier has been detected by the modem or data set.</p> <p>0: dcd_n input is de-asserted (logic 1)<br/>1: dcd_n input is asserted (logic 0)</p> |

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 6              | R          | 0x0         | <p>RI</p> <p>Line State of Ring Indicator</p> <p>This is used to indicate the current state of the modem control line ri_n. This bit is the complement of ri_n. When the Ring Indicator input (ri_n) is asserted it is an indication that a telephone ringing signal has been received by setting the modem or data.</p> <p>0: ri_n input is de-asserted (logic 1)</p> <p>1: ri_n input is asserted (logic 0)</p>                                                                                                       |
| 5              | R          | 0x0         | <p>DSR</p> <p>Line State of Data Set Ready</p> <p>This is used to indicate the current state of the modem control line dsr_n. This bit is the complement of the dsr_n. When the Data Set Ready input (dsr_n) is asserted, it is an indication that the modem or data set is ready to establish communication with UART.</p> <p>0: dsr_n input is de-asserted (logic 1)</p> <p>1: dsr_n input is asserted (logic 0)</p> <p>In Loopback Mode (UART_MCR[4] is set to 1), the DSR is the same as the DTR (UART_MCR[0]).</p> |
| 4              | R          | 0x0         | <p>CTS</p> <p>Line State of Clear To Send</p> <p>This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted, it is an indication that the modem or data set is ready to exchange data with UART.</p> <p>0: cts_n input is de-asserted (logic 1)</p> <p>1: cts_n input is asserted (logic 0)</p> <p>In Loopback Mode (UART_MCR[4] = 1), the CTS is the same as the RTS (UART_MCR[1]).</p>                         |

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3              | RC         | 0x0         | <p>DDCD<br/>Delta Data Carrier Detect</p> <p>This is used to indicate that the modem control line dcd_n has changed since the last time the UART_MSR was read.</p> <p>0: no change on dcd_n since the last read of UART_MSR<br/>1: change on dcd_n since the last read of UART_MSR</p> <p>Reading the UART_MSR clears the DDCD bit.</p> <p><b>Note:</b> If the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs, then the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.</p>                                                                                    |
| 2              | RC         | 0x0         | <p>TERI<br/>Trailing Edge Ring Indicator</p> <p>This is used to indicate that a change in the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the UART_MSR was read.</p> <p>0: no change on ri_n since the last read of UART_MSR<br/>1: change on ri_n since the last read of UART_MSR</p> <p>Reading the UART_MSR clears the TERI bit.</p>                                                                                                                                                                                                                                        |
| 1              | RC         | 0x0         | <p>DDSR<br/>Delta Data Set Ready</p> <p>This is used to indicate that the modem control line dsr_n has changed since the last time the UART_MSR was read.</p> <p>0: no change on dsr_n since the last read of UART_MSR<br/>1: change on dsr_n since the last read of UART_MSR</p> <p>Reading the UART_MSR clears the DDSR bit. In Loopback Mode (UART_MCR[4] = 1), the DDSR reflects changes on the DTR (UART_MCR[0]).</p> <p><b>Note:</b> If the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs, then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</p> |

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0              | RC         | 0x0         | <p>DCTS<br/>Delta Clear to Send<br/>This is used to indicate that the modem control line cts_n has changed since the last time the UART_MSR was read.<br/>0: no change on ctsdsr_n since the last read of UART_MSR<br/>1: change on ctsdsr_n since the last read of UART_MSR<br/>Reading the UART_MSR clears the DCTS bit. In Loopback Mode (UART_MCR[4] = 1), the DCTS reflects changes on the RTS (UART_MCR[1]).</p> <p><b>Note:</b> If the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs, then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</p> |

#### 9.2.6.12 0x001C UART Scratch Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: UART_SCH                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                        |
| 7:0            | R/W        | 0x0         | <p>SCRATCH_REG<br/>Scratch Register<br/>This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART.</p> |

#### 9.2.6.13 0x007C UART Status Register (Default Value: 0x0000\_0006)

| Offset: 0x007C |            |             | Register Name: UART_USR                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
| 31:5           | /          | /           | /                                                                                                                                                                                                     |
| 4              | R          | 0x0         | <p>RFF<br/>RX FIFO Full<br/>This is used to indicate that the RX FIFO is completely full.<br/>0: RX FIFO not full<br/>1: RX FIFO Full<br/>This bit is cleared when the RX FIFO is no longer full.</p> |

| Offset: 0x007C |            |             | Register Name: UART_USR                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
| 3              | R          | 0x0         | <p>RFNE<br/>RX FIFO Not Empty<br/>This is used to indicate that the RX FIFO contains one or more entries.<br/>0: RX FIFO is empty<br/>1: RX FIFO is not empty<br/>This bit is cleared when the RX FIFO is empty.</p> |
| 2              | R          | 0x1         | <p>TFE<br/>TX FIFO Empty<br/>This is used to indicate that the TX FIFO is completely empty.<br/>0: TX FIFO is not empty<br/>1: TX FIFO is empty<br/>This bit is cleared when the TX FIFO is no longer empty.</p>     |
| 1              | R          | 0x1         | <p>TFNF<br/>TX FIFO Not Full<br/>This is used to indicate that the TX FIFO is not full.<br/>0: TX FIFO is full<br/>1: TX FIFO is not full<br/>This bit is cleared when the TX FIFO is full.</p>                      |
| 0              | R          | 0x0         | <p>BUSY<br/>UART Busy Bit<br/>0: Idle or inactive<br/>1: Busy</p>                                                                                                                                                    |

#### 9.2.6.14 0x0080 UART Transmit FIFO Level Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: UART_TFL                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:9           | /          | /           | /                                                                                             |
| 8:0            | R          | 0x0         | <p>TFL<br/>TX FIFO Level<br/>The bit indicates the number of data entries in the TX FIFO.</p> |

### 9.2.6.15 0x0084 UART Receive FIFO Level Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: UART_RFL                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                  |
| 31:9           | /          | /           | /                                                                                                                                                                                            |
| 8:0            | R          | 0x0         | <p>RFL<br/>RX FIFO Level<br/>The bit indicates the number of data entries in the RX FIFO.</p> <p><b>Note:</b> Not use when the RXDMA master is enabled (UART_RXDMA_CTRL[0] is set to 1).</p> |

### 9.2.6.16 0x0088 UART DMA Handshake Configuration Register (Default Value: 0x0000\_00A5)

| Offset: 0x0088 |            |             | Register Name: UART_HSK                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:8           | /          | /           | /                                                                                         |
| 7:0            | R/W        | 0xA5        | <p>Handshake configuration<br/>0xA5: DMA wait cycle mode<br/>0xE5: DMA handshake mode</p> |

### 9.2.6.17 0x008C UART DMA Request Enable Register(Default Value: 0x0000\_0003)

| Offset: 0x008C |            |             | Register Name: UART_DMA_REQ_EN                         |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:3           | /          | /           |                                                        |
| 2              | R/W        | 0x0         | <p>DMA Timeout Enable<br/>0: Disable<br/>1: Enable</p> |
| 1              | R/W        | 0x1         | <p>DMA TX REQ Enable<br/>0: Disable<br/>1: Enable</p>  |
| 0              | R/W        | 0x1         | <p>DMA RX REQ Enable<br/>0: Disable<br/>1: Enable</p>  |

## 9.2.6.18 0x00A4 UART Halt TX Register (Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: UART_HALT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7              | R/W        | 0x0         | <p>PTE<br/>The sending of TX_REQ</p> <p>In DMA1 mode (FIFO on), if the PTE is set to 1 when the TFL in UART_TFL is less than or equal to the trigger value, the controller sends the DMA request. If the PTE is set to 0, when FIFO is empty, the controller sends the DMA request. The DMA request will stop when FIFO is full.</p> <p>In DMA0 mode, if the PTE is set to 1 and FIFO is on, when the TFL in UART_TFL is less than or equal to the trigger value, the controller sends DMA request. If the PTE is set to 1 and FIFO off, when the THR in UART_THR is empty, the controller sends DMA request. If the PTE is set to 0, when FIFO(FIFO Enable) or THR(FIFO Enable) is empty, the controller sends DMA request. Otherwise, the DMA request is cleared.</p> |
| 6              | R/W        | 0x0         | <p>DMA_PTE_RX<br/>The Transmission of RX_DRQ</p> <p>In DMA1 mode, when RFL is more than or equal to the trigger value, or a receive timeout has occurred, the controller sends DRQ.</p> <p>In DMA0 mode, when DMA_PTE_RX = 1 and FIFO is on, if RFL is more than or equal to trig, the controller sends DRQ, else DRQ is cleared. In other cases, once the received data is valid, the controller sends DRQ.</p>                                                                                                                                                                                                                                                                                                                                                        |
| 5              | R/W        | 0x0         | <p>SIR_RX_INVERT<br/>SIR RX Pulse Polarity Invert</p> <p>0: Not invert receiver signal<br/>1: Invert receiver signal</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | <p>SIR_TX_INVERT<br/>SIR TX Pulse Polarity Invert</p> <p>0: Not invert transmit pulse<br/>1: Invert transmit pulse</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x00A4 |            |             | Register Name: UART_HALT                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                           |
| 2              | R/WAC      | 0x0         | <p>CHANGE_UPDATE</p> <p>After the user uses UART_HALT[1] to change the baud rate or LCR configuration, write 1 to update the configuration and wait this bit to self-clear to 0 to finish update process. Writing 0 to this bit has no effect.</p> <p>1: Update trigger, self-clear to 0 when finish update.</p>                      |
| 1              | R/W        | 0x0         | <p>CHCFG_AT_BUSY</p> <p>This is an enable bit for the user to change LCR register configuration and baud rate register (UART_DLH and UART_DLL) when the UART is busy.</p> <p>1: Enable change when busy</p>                                                                                                                           |
| 0              | R/W        | 0x0         | <p>HALT_TX</p> <p>Halt TX</p> <p>This register is used to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.</p> <p>0 : Halt TX disabled<br/>1 : Halt TX enabled</p> <p><b>Note: If FIFOs are not enabled, the setting has no effect on operation.</b></p> |

#### 9.2.6.19 0x00B0 UART DBG DLL Register (Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: UART_DBG_DLL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R          | 0x0         | DEBUG DLL                   |

#### 9.2.6.20 0x00B4 UART DBG DLH Register (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: UART_DBG_DLH |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R          | 0x0         | DEBUG_DLH                   |

### 9.2.6.21 0x00F0 UART FIFO Clock Control Register (Default Value: 0x0000\_0003)

| Offset: 0x00F0 |            |             | Register Name: UART_FCC                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                         |
| 31:8           | R          | 0x0         | FIFO Depth<br>Indicates the depth of TX/RX FIFO                                                                                                     |
| 7:3            | /          | /           | /                                                                                                                                                   |
| 2              | R/W        | 0x0         | RXFIFO Clock Mode<br>0: Sync mode, writing/reading clocks use apb clock<br>1: Sync mode, writing clock uses apb clock, reading clock uses ahb clock |
| 1              | R/W        | 0x1         | TX FIFO Clock Enable<br>0: Clock disable<br>1: Clock enable                                                                                         |
| 0              | R/W        | 0x1         | RX FIFO Clock Enable<br>0: Clock disable<br>1: Clock enable                                                                                         |

### 9.2.6.22 0x0100 UART RXDMA Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: UART_RXDMA_CTRL                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31:24          | /          | /           | /                                                                                                                                                                                         |
| 23:8           | R/W        | 0x0         | RXDMA Timeout Threshold<br>Unit is 1 UART bit time<br>Note that this field is only configurable when RXDMA Busy is 0.                                                                     |
| 7              | /          | /           | /                                                                                                                                                                                         |
| 6              | R/W        | 0x0         | RXDMA Timeout Enable<br>Once enable, the DMA starts a transfer even the data entries in RX FIFO do not reach BLK_SIZE.<br>Note that this field is only configurable when RXDMA Busy is 0. |

| Offset: 0x0100 |            |             | Register Name: UART_RXDMA_CTRL                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 5:4            | R/W        | 0x0         | <p>RXDMA AHB Burst Mode</p> <p>Set for AHB port burst supported</p> <p>INCR8 is recommended, while INCR16 may be unsupported due to the system bus.</p> <p>00: SIGNLE<br/>01: INCR4<br/>10: INCR8<br/>11: INCR16</p> <p>Note that this field is only configurable while RXDMA Busy is 0.</p>                                     |
| 3:2            | R/W        | 0x0         | <p>RXDMA BLK SIZE</p> <p>Every time when data entries in RX FIFO reach BLK_SIZE, start a DMA block transfer. It is recommended that the block size no more than RX FIFO Depth.</p> <p>00: 8 bytes<br/>01: 16 bytes<br/>10: 32 bytes<br/>11: 64 bytes</p> <p>Note that this field is only configurable while RXDMA Busy is 0.</p> |
| 1              | R/W        | 0x0         | <p>RXDMA Mode</p> <p>0: Continous<br/>1: Limited</p> <p>When data transferred reaches the limited count set in RXDMA LIMIT, the DMA stops and the RXDMA Start bit is cleared automatically.</p> <p>Note that this field is only configurable while RXDMA Busy is 0.</p>                                                          |
| 0              | R/W        | 0x0         | <p>RXDMA Enable</p> <p>0: RXDMA Disable<br/>1: RXDMA Enable</p> <p>Note that if the software turns off this bit, the RXDMA will stop after the current block transfer completes, then the software should do a reset to the RX FIFO before re-enable.</p>                                                                        |

#### 9.2.6.23 0x0104 UART RXDMA Start Register (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: UART_RXDMA_STR                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31:2           | /          | /           | /                                                                                                                             |
| 0              | R/WAC      | 0x0         | RXDMA Start<br>Only valid when RXDMA mode is set to 1, it is auto cleared when data transferred reaches the RXDMA Limit Size. |

#### 9.2.6.24 0x0108 UART RXDMA Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: UART_RXDMA_STA                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                       |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                 |
| 1              | R          | 0x0         | Buffer Read Address Updating<br>0: Buffer Read Address Register is ready for updating<br>1: Buffer Read Address Register is busy for updating<br>The software should not update Buffer Read Address Register until this bit is 0. |
| 0              | R          | 0x0         | RXDMA BUSY<br>0: RXDMA is idle<br>1: RXDMA is busy                                                                                                                                                                                |

#### 9.2.6.25 0x010C UART RXDMA Limit Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: UART_RXDMA_LMT                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                           |
| 31:16          | /          | /           | /                                                                                                                                                     |
| 15:0           | R/W        | 0x0         | RXDMA Limit Size<br>Only valid when RXDMA Mode is set to 1, and the unit is byte.<br>Note that this field is only configurable while RXDMA Busy is 0. |

### 9.2.6.26 0x0110 UART RXDMA Buffer Start Address Low Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: UART_RXDMA_SADDRL                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:0           | R/W        | 0x0         | RXDMA Buffer Start Address [31:0]<br>Byte address<br>Note that this field is only configurable while RXDMA Busy is 0. |

### 9.2.6.27 0x0114 UART RXDMA Buffer Start Address High Register (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: UART_RXDMA_SADDRH                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:2           | /          | /           | /                                                                                                                      |
| 1:0            | R/W        | 0x0         | RXDMA Buffer Start Address [33:32]<br>Byte address<br>Note that this field is only configurable while RXDMA Busy is 0. |

### 9.2.6.28 0x0118 UART RXDMA Buffer Length Register (Default Value: 0x0000\_0000)

| Offset: 0x0118 |            |             | Register Name: UART_RXDMA_BL                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:16          | /          | /           | /                                                                                                       |
| 15:0           | R/W        | 0x0         | RXDMA Buffer Length<br>Unit is byte<br>Note that this field is only configurable while RXDMA Busy is 0. |

### 9.2.6.29 0x0120 UART RXDMA Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0120 |            |             | Register Name: UART_RXDMA_IE                                  |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:4           | /          | /           | /                                                             |
| 3              | R/W        | 0x0         | RXDMA Buffer Overrun<br>RXDMA Buffer Overrun Interrupt Enable |

| Offset: 0x0120 |            |             | Register Name: UART_RXDMA_IE                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 2              | R/W        | 0x0         | RXDMA Timeout Done<br>RXDMA Timeout Done Interrupt Enable |
| 1              | R/W        | 0x0         | RXDMA BLK Done<br>RXDMA BLK Done Interrupt Enable         |
| 0              | R/W        | 0x0         | RXDMA Limit Done<br>RXDMA Limit Done Interrupt Enable     |

#### 9.2.6.30 0x0124 UART RXDMA Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: UART_RXDMA_IS                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:4           | /          | /           | /                                                                                          |
| 3              | R/W1C      | 0x0         | RXDMA Buffer Overrun<br>Asserted when the RXDMA buffer is overflow.                        |
| 2              | R/W1C      | 0x0         | RXDMA Timeout Done<br>Asserted when a DMA transfer caused by timeout is done.              |
| 1              | R/W1C      | 0x0         | RXDMA BLK Done<br>Asserted when a DMA block transfer is done.                              |
| 0              | R/W1C      | 0x0         | RXDMA Limit Done<br>Asserted when data transferred reaches limit size in RXDMA Limit Mode. |

#### 9.2.6.31 0x0128 UART RXDMA Write Address Low Register (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: UART_RXDMA_WADDR                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                         |
| 31:0           | R          | 0x0         | RXDMA Current Write Address[31:0]<br>Updated when every DMA transfer is done<br>It is byte address. |

#### 9.2.6.32 0x012C UART RXDMA Write Address High Register (Default Value: 0x0000\_0000)

| Offset: 0x012C |            |             | Register Name: UART_RXDMA_WADDRH                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:2           | /          | /           | /                                                                                                    |
| 1:0            | R          | 0x0         | RXDMA Current Write Address[33:32]<br>Updated when every DMA transfer is done<br>It is byte address. |

#### 9.2.6.33 0x0130 UART RXDMA Read Address Low Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: UART_RXDMA_RADDRL                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:0           | R/W        | 0x0         | RXDMA Current Read Address[31:0]<br>Software should update this register after reading data in RXDMA Buffer in time<br>It is byte address.<br>The software should not update Buffer Read Address Register until UART_RXDMA_STA[1] is 0. The software should update Read Address High Register first, and then Read Address Low Register, even there is no change on Read Address High Register. |

#### 9.2.6.34 0x0134 UART RXDMA Read Address High Register (Default Value: 0x0000\_0000)

| Offset: 0x0134 |            |             | Register Name: UART_RXDMA_RADDRH                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1:0            | R/W        | 0x0         | RXDMA Current Read Address[33:32]<br>Software should update this register after reading data in RXDMA Buffer in time.<br>It is byte address.<br>The software should not update Buffer Read Address Register until UART_RXDMA_STA[1] is 0. The software should update Read Address High Register first and then Read Address Low Register , even there is no change on Read Address High Register. |

### 9.2.6.35 0x0138 UART RXDMA Data Count Register (Default Value: 0x0000\_0000)

| Offset: 0x0138 |            |             | Register Name: UART_RXDMA_DCNT                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:16          | /          | /           | /                                                                                                                                                                                      |
| 15:0           | R          | 0x0         | RXDMA Data Count<br>Only valid while RXDMA Mode is set to 1, it is used for counting the data transferred by RXDMA, and is cleared when reaches RXDMA Limit Size.<br>Its unit is byte. |

## 9.3 SPI

### 9.3.1 Overview

The Serial Peripheral Interface (SPI) is a full-duplex, synchronous, four-wire serial communication interface between a CPU and SPI-compliant external devices. The SPI controller contains a 64 x 8 bits receiver buffer (RXFIFO) and a 64 x 8 bits transmit buffer (TXFIFO). It can work in master mode and slave mode.

The SPI has the following features:

- Full-duplex synchronous serial interface
- Master/slave configurable
- 8-bit wide by 64-entry FIFO for both transmit and receive data
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable
- Supports interrupts and DMA
- Supports mode0, mode1, mode2, and mode3
- Supports 3-wire/4-wire SPI
- Supports programmable serial data frame length: 1 bit to 32 bits
- Supports standard SPI, dual-output/dual-input SPI, dual I/O SPI, quad-output/quad-input SPI
- Supports maximum IO rate of the mass production: 100 MHz

### 9.3.2 Block Diagram

Figure 9-20 shows a block diagram of the SPI.

Figure 9-20 SPI Block Diagram



SPI contains the following sub-blocks:

Table 9-6 SPI Sub-blocks

| Sub-block      | Description                                                                                                                                                                       |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| spi_rf         | Responsible for implementing the internal register, interrupt, and DMA Request.                                                                                                   |
| spi_tbuf       | The data length transmitted from AHB to TXFIFO is converted into 8 bits, then the data is written into the RXFIFO.                                                                |
| spi_rbuf       | The block is used to convert the RXFIFO data into the reading data length of AHB.                                                                                                 |
| txfifo, rxfifo | The data transmitted from the SPI to the external serial device is written into the TXFIFO; the data received from the external serial device into SPI is pushed into the RXFIFO. |
| spi_cmu        | Responsible for implementing SPI bus clock, chip select, internal sample, and the generation of transfer clock.                                                                   |
| spi_tx         | Responsible for implementing SPI data transfer, the interface of the internal TXFIFO, and status register.                                                                        |
| spi_rx         | Responsible for implementing SPI data receive, the interface of the internal RXFIFO, and status register.                                                                         |

### 9.3.3 Functional Description

#### 9.3.3.1 External Signals

The following table describes the external signals of SPI. The MOSI and MISO are bidirectional I/O, when SPI is as a master device, the CLK and CS are the output pin; when SPI is as a slave device, the CLK and CS are the input pin. When using SPI, the corresponding PADs are selected as SPI function via section 9.7 “[GPIO](#)”.

**Table 9-7 SPI External Signals**

| Signal    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                | Type |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| SPI0-CS   | SPI0 chip select signal, low active<br>When the device is not selected, data will not be accepted via the SI pin, and the SO pin will stop transmission.                                                                                                                                                                                                                                                                                                   | I/O  |
| SPI0-CLK  | SPI0 clock signal<br>This pin is used to provide a clock to the device and is used to control the flow of data to and from the device.                                                                                                                                                                                                                                                                                                                     | I/O  |
| SPI0-MOSI | SPI0 master data out, slave data in                                                                                                                                                                                                                                                                                                                                                                                                                        | I/O  |
| SPI0-MISO | SPI0 master data in, slave data out                                                                                                                                                                                                                                                                                                                                                                                                                        | I/O  |
| SPI0-WP   | Write protection and low active<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode.                                                                                                                                                                                                                                                                                                                            | I/O  |
| SPI0-HOLD | When the device is selected and a serial sequence is underway, the HOLD pin can be used to temporarily pause the serial communication with the master device without deselecting or resetting the serial sequence. While the HOLD pin is asserted, the SO pin is at high impedance, and all transitions on the SCK pin and data on the SI pin are ignored.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode. | I/O  |

#### 9.3.3.2 Clock Sources

The SPI controller gets 5 different clock sources, users can select one of them to make SPI clock source. The following table describes the clock sources for SPI. For more details on the clock setting, configuration, and gating information, see section 3.3 “[CCU](#)”.

**Table 9-8 SPI Clock Sources**

| Clock Sources | Description    |
|---------------|----------------|
| HOSC          | 24 MHz Crystal |

| Clock Sources    | Description                                 |
|------------------|---------------------------------------------|
| PLL_PERI(1X)     | Peripheral Clock, default value is 600 MHz  |
| PLL_PERI(2X)     | Peripheral Clock, default value is 1200 MHz |
| PLL_AUDIO0(DIV2) | Audio Clock, the default value is 1536 MHz  |
| PLL_AUDIO0(DIV5) | Audio Clock, the default value is 614.4 MHz |

### 9.3.3.3 Typical Application

Figure 9-21 shows the application block diagram when the SPI master device is connected to a slave device.

Figure 9-21 SPI Application Block Diagram



### 9.3.3.4 SPI Transmit Format

The SPI supports 4 different formats for data transfer. The software can select one of the four modes in which the SPI works by setting the bit1 (Polarity) and bit0 (Phase) of [SPI\\_TCR](#). The SPI controller master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

The CPOL ([SPI\\_TCR\[1\]](#)) defines the polarity of the clock signal (SPI\_SCLK). The SPI\_SCLK is a high level when CPOL is '1' and it is a low level when CPOL is '0'. The CPHA ([SPI\\_TCR\[0\]](#)) decides whether the leading edge of SPI\_SCLK is used to setup or sample data. The leading edge is used to setup data when CPHA is '1', and sample data when CPHA is '0'. The following table lists the four modes.

Table 9-9 SPI Transmit Format

| Mode  | Polarity (CPOL) | Phase (CPHA) | Leading Edge              | Trailing Edge             |
|-------|-----------------|--------------|---------------------------|---------------------------|
| Mode0 | 0               | 0            | Sample on the rising edge | Setup on the falling edge |

| Mode  | Polarity (CPOL) | Phase (CPHA) | Leading Edge               | Trailing Edge              |
|-------|-----------------|--------------|----------------------------|----------------------------|
| Mode1 | 0               | 1            | Setup on the rising edge   | Sample on the falling edge |
| Mode2 | 1               | 0            | Sample on the falling edge | Setup on the rising edge   |
| Mode3 | 1               | 1            | Setup on the falling edge  | Sample on the rising edge  |

Figure 9-22 and Figure 9-23 describe four waveforms for SPI\_SCLK.

**Figure 9-22 SPI Phase 0 Timing Diagram**



**Figure 9-23 SPI Phase 1 Timing Diagram**



### 9.3.3.5 SPI Master and Slave Mode

The SPI controller can be configured to a master or slave device. The master mode is selected by setting the MODE bit ([SPI\\_GCR\[1\]](#)); the slave mode is selected by clearing the MODE bit.

In master mode, the SPI\_CLK is generated and transmitted to the external device, and the data from the TX FIFO is transmitted on the MOSI pin, the data from the slave device is received on the MISO pin and sent to RX FIFO. The Chip Select (SPI\_SS) is an active low signal, and it must be set low before the data are transmitted or received. The SPI\_SS can be selected the auto control mode or software manual control mode. When using the auto control, the SS\_OWNER ([SPI\\_TCR\[6\]](#)) must be cleared (default value is 0); when using the manual control, the SS\_OWNER must be set. And the level of SPI\_SS is controlled by SS\_LEVEL ([SPI\\_TCR\[7\]](#)).

In slave mode, after the software selects the MODE bit ([SPI\\_GCR\[1\]](#)) to '0', it waits for master initiate a transaction. When the master asserts SPI\_SS, then SPI\_CLK is transmitted to the slave device, the slave data is transmitted from TX FIFO on the MISO pin and the data from the MOSI pin is received in RX FIFO.

### 9.3.3.6 SPI 3-Wire Mode

The SPI 3-wire mode is only valid when the SPI controller work in master mode, and is selected when the Work Mode Select bit ([SPI\\_BATC\[1:0\]](#)) is equal to 0x2. And in the 3-wire mode, the input data and the output data use the same single data line. The following figure describes the 3-wire mode.

Figure 9-24 SPI 3-Wire Mode



### 9.3.3.7 SPI Dual-Input/Dual-Output and Dual I/O Mode

The dual read mode (SPI x2) is selected when the DRM is set in [SPI\\_BCC\[28\]](#). Using the dual mode allows data to be transferred to or from the device at double the rate of standard single mode, the data can be read at fast speed using two data bits (MOSI and MISO) at a time. The following figure describes the dual-input/dual-output SPI (Figure 9-25) and the dual I/O SPI (Figure 9-26).

Figure 9-25 SPI Dual-Input/Dual-Output Mode



In the dual-input/dual-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line, only the data bytes are output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

Figure 9-26 SPI Dual I/O Mode



In the dual I/O SPI mode, only the command bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. The address bytes and the dummy bytes output in a unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

### 9.3.3.8 SPI Quad-Input/Quad-Output Mode

The quad read mode (SPI x4) is selected when the Quad\_EN is set in [SPI\\_BCC](#)[29]. Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode, the data can be read at fast speed using four data bits (MOSI, MISO, IO2 (WP#) and IO3 (HOLD#)) at the same time. The following figure describes the quad-input/quad-output SPI.

**Figure 9-27 SPI Quad-Input/Quad-Output Mode**



In the quad-input/quad-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through SPI\_MOSI line. Only the data bytes output (write) and input (read) in a unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP#, and SPI\_HOLD#.

### 9.3.3.9 Transmission/Reception Bursts in Master Mode

In SPI master mode, the transmission and reception bursts (byte in unit) are configured before the SPI transfers the serial data between the processor and external device. The transmission bursts are written in MWTC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). The transmission bursts in single mode before automatically sending dummy bursts are written in STC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). For dummy data, the SPI controller can automatically send before receiving by writing DBC (bit[27:24]) in the [SPI Master Transmit Counter Register](#). If users do not use the SPI controller to send dummy data automatically, then the dummy bursts are used as the transmission counters to write together in MWTC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). In master mode, the total burst numbers are written in MBC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). When all transmission and reception bursts are transferred, the SPI controller will send a completed interrupt, at the same time, the SPI controller will clear [DBC](#), [MWTC](#), and [MBC](#).

### 9.3.3.10 SPI Sample Mode and Run Clock Configuration

The SPI controller runs at 3 kHz–100 MHz at its interface to external SPI devices. The internal SPI clock should run at the same frequency as the outgoing clock in the master mode. The SPI clock is selected from different clock sources, the SPI must configure different work mode. There are three work modes: normal sample mode, delay half-cycle sample mode, delay one-cycle sample mode. The Delay half-cycle sample mode is the default mode of the SPI controller. When the SPI runs at 40 MHz or below 40 MHz, the SPI can work at normal sample mode or delay half-cycle sample mode. When the SPI runs over 80 MHz, setting the SDC bit in the [SPI Transfer Control Register](#) to '1' makes the internal read sample point with a half-cycle delay of SPI\_CLK, which is used in high speed read operation to reduce the error caused by the time delay of SPI\_CLK between master and slave.

Table 9-10 and Table 9-11 show the different configurations of the SPI sample mode.

**Table 9-10 SPI Old Sample Mode and Run Clock**

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | Run Clock |
|-------------------------|------------|------------|-----------|
| normal sample           | 1          | 0          | <=24 MHz  |
| delay half cycle sample | 0          | 0          | <=40 MHz  |
| delay one cycle sample  | 0          | 1          | >=80 MHz  |



**CAUTION**

The remaining spectrum is not recommended. Because when the output delay of SPI flash (refer to the datasheet of the manufacturer for the specific delay time) is the same with the half-cycle time of SPI working clock, the variable edge of the output data for the device bumps into the clock sampling edge of the controller, so setting 1 cycle of sampling delay would cause stability problem.

**Table 9-11 SPI New Sample Mode**

| SPI Sample Mode         | SDM (bit13) | SDC (bit11) | SDC1 (bit15) |
|-------------------------|-------------|-------------|--------------|
| normal sample           | 1           | 0           | 0            |
| delay half cycle sample | 0           | 0           | 0            |
| delay one cycle sample  | 0           | 1           | 0            |
| delay 1.5 cycle sample  | 1           | 1           | 0            |
| delay 2 cycle sample    | 1           | 0           | 1            |
| delay 2.5 cycle sample  | 0           | 0           | 1            |
| delay 3 cycle sample    | 0           | 1           | 1            |

### 9.3.3.11 SPI Error Conditions

If any error conditions occur, the hardware will set the corresponding status bits in the [SPI Interrupt Status Register](#) and stop the transfer. For the SPI controller, the following error scenarios can happen.

#### 1. TX\_FIFO Underrun

The TX\_FIFO underrun happens when the CPU/DMA reads data from TX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_UDF bit in the [SPI Interrupt Status Register](#). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the TF\_UDF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#).

#### 2. TX\_FIFO Overflow

The TX\_FIFO overflow happens when the CPU/DMA writes data into the TX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_OVF bit in the [SPI Interrupt Status Register](#). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the TF\_OVF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#).

#### 3. RX\_FIFO Underrun

The RX\_FIFO underrun happens when the CPU/DMA reads data from RX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_UDF bit in the [SPI Interrupt Status Register](#). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the RF\_UDF bit. To start a new transaction, the software has to reset the fifo by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#).

#### 4. RX\_FIFO Overflow

The RX\_FIFO overflow happens when the CPU/DMA writes data into the RX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_OVF bit in the [SPI Interrupt Status Register](#). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the RF\_OVF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#).

### 9.3.4 Programming Guidelines

#### 9.3.4.1 Writing/Reading Data Process

The SPI transfers serial data between the processor and the external device. The CPU mode and DMA mode are the two main operational modes for SPI. For each SPI, the data is simultaneously transmitted (shifted out serially) and received (shifted in serially). The SPI has 2 channels, including the TX channel and RX channel. The TX channel has the path from TX FIFO to the external device. The RX channel has the path from the external device to RX FIFO.

**Write Data:** The CPU or DMA must write data on the [SPI\\_TXD](#) register, the data on the register are automatically moved to TX FIFO.

**Read Data:** To read data from RX FIFO, the CPU or DMA must access the [SPI\\_RXD](#) register and the data are automatically sent to the [SPI\\_RXD](#) register.

In CPU or DMA mode, the SPI sends a completed interrupt ([SPI\\_ISR\[TC\]](#)) to the processor after each transmission is complete.

**CPU Mode**
**Figure 9-28 SPI Write/Read Data in CPU Mode**


**DMA Mode**
**Figure 9-29 SPI Write/Read Data in DMA Mode**


### 9.3.4.2 Calibrate Delay Chain

The SPI has one delay chain which is used to generate delay to make proper timing between the internal SPI clock signal and data signals. Delay chain is made up of 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

The steps to calibrate delay chain are as follows:

- Step 1** Enable SPI. To calibrate the delay chain by the operation registers in SPI, the SPI must be enabled through AHB reset and AHB clock gating control registers.
- Step 2** Configure a proper clock for SPI. The calibration delay chain is based on the clock for SPI from CCU.
- Step 3** Set proper initial delay value. Write 0xA0 to the [SPI Sample Delay Control Register](#) to set initial delay value 0x20 to delay chain. Then write 0x0 to the [SPI Sample Delay Control Register](#) to clear this value.
- Step 4** Write 0x8000 to the [SPI Sample Delay Control Register](#) to start to calibrate the delay chain.
- Step 5** Wait until the flag (bit14 in the [SPI Sample Delay Control Register](#)) of calibration done is set. The number of delay cells is shown at the bit[13:8] of the [SPI Sample Delay Control Register](#). The delay time generated by these delay cells is equal to the cycle of the SPI clock nearly. This value is the result of calibration.
- Step 6** Calculate the delay time of one delay cell according to the cycle of the SPI clock and the result of calibration.

### 9.3.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI0        | 0x04025000   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| SPI_GCR       | 0x0004 | SPI Global Control Register       |
| SPI_TCR       | 0x0008 | SPI Transfer Control Register     |
| SPI_IER       | 0x0010 | SPI Interrupt Control Register    |
| SPI_ISR       | 0x0014 | SPI Interrupt Status Register     |
| SPI_FCR       | 0x0018 | SPI FIFO Control Register         |
| SPI_FSR       | 0x001C | SPI FIFO Status Register          |
| SPI_WCR       | 0x0020 | SPI Wait Clock Register           |
| SPI_SAMP_DL   | 0x0028 | SPI Sample Delay Control Register |
| SPI_MBC       | 0x0030 | SPI Master Burst Counter Register |

| Register Name     | Offset | Description                                  |
|-------------------|--------|----------------------------------------------|
| SPI_MTC           | 0x0034 | SPI Master Transmit Counter Register         |
| SPI_BCC           | 0x0038 | SPI Master Burst Control Register            |
| SPI_BATCR         | 0x0040 | SPI Bit-Aligned Transfer Configure Register  |
| SPI_BA_CCR        | 0x0044 | SPI Bit-Aligned Clock Configuration Register |
| SPI_TBR           | 0x0048 | SPI TX Bit Register                          |
| SPI_RBR           | 0x004C | SPI RX Bit Register                          |
| SPI_NDMA_MODE_CTL | 0x0088 | SPI Normal DMA Mode Control Register         |
| SPI_TXD           | 0x0200 | SPI TX Data Register                         |
| SPI_RXD           | 0x0300 | SPI RX Data Register                         |

### 9.3.6 Register Description

#### 9.3.6.1 0x0004 SPI Global Control Register (Default Value: 0x0000\_0080)

| Offset:0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                                                                                                                                               |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                          |
| 31            | R/WAC      | 0x0         | <p>SRST<br/>Soft reset</p> <p>Writing ‘1’ to this bit will clear the SPI controller, and auto clear to ‘0’ when reset operation completes.</p> <p>Writing ‘0’ to this bit has no effect.</p>                                                                                                         |
| 30:8          | /          | /           | /                                                                                                                                                                                                                                                                                                    |
| 7             | R/W        | 0x1         | <p>TP_EN<br/>Transmit Pause Enable</p> <p>In master mode, it is used to control the transmit state machine to stop smart burst sending when RX FIFO is full.</p> <p>0: Normal operation, ignore RXFIFO status</p> <p>1: Stop transmit data when RXFIFO full</p> <p>Cannot be written when XCH=1.</p> |
| 6:3           | /          | /           | /                                                                                                                                                                                                                                                                                                    |
| 2             | R/W        | 0x0         | <p>MODE_SELEC<br/>Sample Timing Mode Select</p> <p>0: Old mode of Sample Timing</p> <p>1: New mode of Sample Timing</p> <p>Cannot be written when XCH=1.</p>                                                                                                                                         |

| Offset:0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                   |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                              |
| 1             | R/W        | 0x0         | <p>MODE</p> <p>SPI Function Mode Select</p> <p>0: Slave mode</p> <p>1: Master mode</p> <p>Cannot be written when XCH=1.</p>                                              |
| 0             | R/W        | 0x0         | <p>EN</p> <p>SPI Module Enable Control</p> <p>0: Disable</p> <p>1: Enable</p> <p>After transforming from bit_mode to byte_mode, it must enable the SPI module again.</p> |

### 9.3.6.2 0x0008 SPI Transfer Control Register (Default Value: 0x0000\_0087)

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31             | R/WAC      | 0x0         | <p>XCH</p> <p>Exchange Burst</p> <p>In master mode, it is used to start SPI burst.</p> <p>0: Idle</p> <p>1: Initiates exchange.</p> <p>Writing “1” to this bit will start the SPI burst, and will auto-clear after finishing the bursts transfer specified by SPI_MBC. Writing “1” to SRST (SPI_GCR[31]) will also clear this bit. Writing ‘0’ to this bit has no effect.</p> <p>Cannot be written when XCH=1.</p>                                     |
| 30:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15             | R/W        | 0x0         | <p>SDC1</p> <p>Master Sample Data Control register1</p> <p>Set this bit to ‘1’ to make the internal read sample point with a delay of half-cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK between master and slave.</p> <p>0: normal operation, do not delay the internal read sample point</p> <p>1: delay the internal read sample point</p> <p>Cannot be written when XCH=1.</p> |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14             | R/W        | 0x0         | <p>SDDM<br/>Sending Data Delay Mode<br/>0: Normal sending<br/>1: Delay sending<br/>Set the bit to "1" to make the data that should be sent with a delay of half-cycle for SPI_CLK in dual IO mode of SPI mode0.<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                         |
| 13             | R/W        | 0x0         | <p>SDM<br/>Master Sample Data Mode<br/>0: Delay sample mode<br/>1: Normal sample mode<br/>In normal sample mode, the SPI master samples the data at the correct edge for each SPI mode;<br/>In delay sample mode, the SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.<br/>Cannot be written when XCH=1.</p>                                                |
| 12             | R/W        | 0x0         | <p>FBS<br/>First Transmit Bit Select<br/>0: MSB first<br/>1: LSB first<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                                                                                                  |
| 11             | R/W        | 0x0         | <p>SDC<br/>Master Sample Data Control<br/>Set this bit to '1' to make the internal read sample point with a delay of half-cycle for SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK between master and slave.<br/>0: Normal operation, do not delay the internal read sample point<br/>1: Delay the internal read sample point<br/>Cannot be written when XCH=1.</p> |
| 10             | R/W        | 0x0         | <p>RPSM<br/>Rapids Mode Select<br/>Select rapid mode for high speed write.<br/>0: Normal write mode<br/>1: Rapid write mode<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                                             |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 9              | R/W        | 0x0         | <p>DDB<br/>Dummy Burst Type<br/>0: The bit value of dummy SPI burst is zero<br/>1: The bit value of dummy SPI burst is one<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                        |
| 8              | R/W        | 0x0         | <p>DHB<br/>Discard Hash Burst<br/>In master mode, it controls whether discarding unused SPI bursts<br/>0: Receiving all SPI bursts in the BC period<br/>1: Discard unused SPI bursts, only fetching the SPI bursts during the dummy burst period. The burst number is specified by TC.<br/>Cannot be written when XCH=1.</p>            |
| 7              | R/W        | 0x1         | <p>SS_LEVEL<br/>When control SS signal manually (SS_OWNER (SPI_TCR[6]) == 1), set this bit to '1' or '0' to control the level of SS signal.<br/>0: Set SS to low<br/>1: Set SS to high<br/>Cannot be written when XCH=1.</p>                                                                                                            |
| 6              | R/W        | 0x0         | <p>SS_OWNER<br/>SS Output Owner Select<br/>Usually, the controller sends the SS signal automatically with data together. When this bit is set to 1, the software must manually write SS_LEVEL (SPI_TCR[7]) to 1 or 0 to control the level of the SS signal.<br/>0: SPI controller<br/>1: Software<br/>Cannot be written when XCH=1.</p> |
| 5:4            | R/W        | 0x0         | <p>SS_SEL<br/>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted<br/>10: SPI_SS2 will be asserted<br/>11: SPI_SS3 will be asserted<br/>Cannot be written when XCH=1.</p>                                                                        |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                       |
| 3              | R/W        | 0x0         | <p>SSCTL</p> <p>In master mode, this bit selects the output waveform for the SPI_SSx signal. Only valid when SS_OWNER (SPI_TCR[6])= 0.</p> <p>0: SPI_SSx remains asserted between SPI bursts</p> <p>1: Negate SPI_SSx between SPI bursts</p> <p>Cannot be written when XCH=1.</p> |
| 2              | R/W        | 0x1         | <p>SPOL</p> <p>SPI Chip Select Signal Polarity Control</p> <p>0: Active high polarity (0 = Idle)</p> <p>1: Active low polarity (1 = Idle)</p> <p>Cannot be written when XCH=1.</p>                                                                                                |
| 1              | R/W        | 0x1         | <p>CPOL</p> <p>SPI Clock Polarity Control</p> <p>0: Active high polarity (0 = Idle)</p> <p>1: Active low polarity (1 = Idle)</p> <p>Cannot be written when XCH=1.</p>                                                                                                             |
| 0              | R/W        | 0x1         | <p>CPHA</p> <p>SPI Clock/Data Phase Control</p> <p>0: Phase 0 (Leading edge for sample data)</p> <p>1: Phase 1 (Leading edge for setup data)</p> <p>Cannot be written when XCH=1.</p>                                                                                             |

### 9.3.6.3 0x0010 SPI Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 31:14          | /          | /           | /                                                                                                                                                         |
| 13             | R/W        | 0x0         | <p>SS_INT_EN</p> <p>SSI Interrupt Enable</p> <p>Chip select signal (SSx) from the valid state to the invalid state</p> <p>0: Disable</p> <p>1: Enable</p> |

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 12             | R/W        | 0x0         | TC_INT_EN<br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable        |
| 11             | R/W        | 0x0         | TF_UDR_INT_EN<br>TXFIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable       |
| 10             | R/W        | 0x0         | TF_OVF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 9              | R/W        | 0x0         | RF_UDR_INT_EN<br>RXFIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable       |
| 8              | R/W        | 0x0         | RF_OVF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 7              | /          | /           | /                                                                                  |
| 6              | R/W        | 0x0         | TF_FUL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 5              | R/W        | 0x0         | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4              | R/W        | 0x0         | TX_ERQ_INT_EN<br>TX FIFO Empty Request Interrupt Enable<br>0: Disable<br>1: Enable |
| 3              | /          | /           | /                                                                                  |

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 2              | R/W        | 0x0         | RF_FUL_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 1              | R/W        | 0x0         | RX_EMP_INT_EN<br>RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 0              | R/W        | 0x0         | RF_RDY_INT_EN<br>RX FIFO Ready Request Interrupt Enable<br>0: Disable<br>1: Enable |

#### 9.3.6.4 0x0014 SPI Interrupt Status Register (Default Value: 0x0000\_0032)

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                           |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                     |
| 13             | R/W1C      | 0x0         | SSI<br>SS Invalid Interrupt<br>When SSI is 1, it indicates that SPI_SS has changed from valid state to invalid state. Writing 1 to this bit clears it.                                                                                                                                                                                                                |
| 12             | R/W1C      | 0x0         | TC<br>Transfer Completed<br>In master mode, it indicates that all bursts specified by SPI_MBC have been exchanged. In other conditions, when setting, this bit indicates that all the data in TXFIFO has been loaded in the Shift register, and the Shift register has shifted out all the bits. Writing 1 to this bit clears it.<br>0: Busy<br>1: Transfer completed |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
| 11             | R/W1C      | 0x0         | <p>TF_UDF<br/>TXFIFO Underrun<br/>This bit is set when the TXFIFO is underrun. Writing 1 to this bit clears it.<br/>0: TXFIFO is not underrun<br/>1: TXFIFO is underrun</p>                 |
| 10             | R/W1C      | 0x0         | <p>TF_OVF<br/>TXFIFO Overflow<br/>This bit is set when the TXFIFO is overflowed. Writing 1 to this bit clears it.<br/>0: TXFIFO is not overflowed<br/>1: TXFIFO is overflowed</p>           |
| 9              | R/W1C      | 0x0         | <p>RX_UDF<br/>RXFIFO Underrun<br/>When set, this bit indicates that RXFIFO is underrun. Writing 1 to this bit clears it.<br/>0: RXFIFO is not underrun<br/>1: RXFIFO is underrun</p>        |
| 8              | R/W1C      | 0x0         | <p>RX_OVF<br/>RXFIFO Overflow<br/>When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br/>0: RXFIFO is not overflowed<br/>1: RXFIFO is overflowed</p> |
| 7              | /          | /           | /                                                                                                                                                                                           |
| 6              | R/W1C      | 0x0         | <p>TX_FULL<br/>TXFIFO Full<br/>This bit is set when the TXFIFO is full. Writing 1 to this bit clears it.<br/>0: TXFIFO is not Full<br/>1: TXFIFO is Full</p>                                |
| 5              | R/W1C      | 0x1         | <p>TX_EMP<br/>TXFIFO Empty<br/>This bit is set when the TXFIFO is empty. Writing 1 to this bit clears it.<br/>0: TXFIFO contains one or more words<br/>1: TXFIFO is empty</p>               |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
| 4              | R/W1C      | 0x1         | <p>TX_READY<br/>TXFIFO Ready</p> <p>0: TX_WL &gt; TX_TRIG_LEVEL<br/>1: TX_WL &lt;= TX_TRIG_LEVEL</p> <p>This bit will be immediately set to 1 if TX_WL &lt;= TX_TRIG_LEVEL. Writing "1" to this bit clears it. The TX_WL is the water level of TXFIFO.</p> |
| 3              | /          | /           | /                                                                                                                                                                                                                                                          |
| 2              | R/W1C      | 0x0         | <p>RX_FULL<br/>RXFIFO Full.</p> <p>This bit is set when the RXFIFO is full. Writing 1 to this bit clears it.</p> <p>0: Not Full<br/>1: Full</p>                                                                                                            |
| 1              | R/W1C      | 0x1         | <p>RX_EMP<br/>RXFIFO Empty</p> <p>This bit is set when the RXFIFO is empty. Writing 1 to this bit clears it.</p> <p>0: Not empty<br/>1: empty</p>                                                                                                          |
| 0              | R/W1C      | 0x0         | <p>RX_RDY<br/>RXFIFO Ready</p> <p>0: RX_WL &lt; RX_TRIG_LEVEL<br/>1: RX_WL &gt;= RX_TRIG_LEVEL</p> <p>This bit will be immediately set to 1 if RX_WL &gt;= RX_TRIG_LEVEL. Writing "1" to this bit clears it. The RX_WL is the water level of RXFIFO.</p>   |

### 9.3.6.5 0x0018 SPI FIFO Control Register (Default Value: 0x0040\_0001)

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                            |
| 31             | R/WAC      | 0x0         | <p>TX_FIFO_RST<br/>TX FIFO Reset</p> <p>Writing '1' to this bit will reset the control portion of the TX FIFO and auto clear to '0' when completing reset operation, writing to '0' has no effect.</p> |

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                           |
| 30             | R/W        | 0x0         | <p>TF_TEST_ENB<br/>TX Test Mode Enable<br/>0: Disable<br/>1: Enable</p> <p>In normal mode, the TXFIFO can only be read by the SPI controller, writing '1' to this bit will switch the read and write function of the TXFIFO to AHB bus. This bit is used to test the TXFIFO, do not set in normal operation, and do not set RF_TEST and TF_TEST at the same time.</p> |
| 29:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                     |
| 24             | R/W        | 0x0         | <p>TF_DRO_EN<br/>TXFIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                           |
| 23:16          | R/W        | 0x40        | <p>TX_TRIG_LEVEL<br/>TXFIFO Empty Request Trigger Level</p>                                                                                                                                                                                                                                                                                                           |
| 15             | R/WAC      | 0x0         | <p>RF_RST<br/>RXFIFO Reset</p> <p>Writing '1' to this bit will reset the control portion of the receiver FIFO, and auto clear to '0' when completing reset operation, writing '0' to this bit has no effect.</p>                                                                                                                                                      |
| 14             | R/W        | 0x0         | <p>RF_TEST<br/>RX Test Mode Enable<br/>0: Disable<br/>1: Enable</p> <p>In normal mode, the RXFIFO can only be written by the SPI controller, writing '1' to this bit will switch the read and write function of RXFIFO to AHB bus. This bit is used to test the RXFIFO, do not set in normal operation, and do not set RF_TEST and TF_TEST at the same time.</p>      |
| 13:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                     |
| 8              | R/W        | 0x0         | <p>RF_DRQ_EN<br/>RX FIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                          |
| 7:0            | R/W        | 0x1         | <p>RX_TRIG_LEVEL<br/>RX FIFO Ready Request Trigger Level</p>                                                                                                                                                                                                                                                                                                          |

### 9.3.6.6 0x001C SPI FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31             | R          | 0x0         | TB_WR<br>TX FIFO Write Buffer Write Enable                                                                                                                                           |
| 30:28          | R          | 0x0         | TB_CNT<br>TX FIFO Write Buffer Counter<br>These bits indicate the number of words in TX FIFO Write Buffer                                                                            |
| 27:24          | /          | /           | /                                                                                                                                                                                    |
| 23:16          | R          | 0x0         | TF_CNT<br>TX FIFO Counter<br>These bits indicate the number of words in TX FIFO<br>0: 0 byte in TX FIFO<br>1: 1 byte in TX FIFO<br>...<br>64: 64 bytes in TX FIFO<br>other: Reserved |
| 15             | R          | 0x0         | RB_WR<br>RX FIFO Read Buffer Write Enable                                                                                                                                            |
| 14:12          | R          | 0x0         | RB_CNT<br>RX FIFO Read Buffer Counter<br>These bits indicate the number of words in RX FIFO Read Buffer                                                                              |
| 11:8           | /          | /           | /                                                                                                                                                                                    |
| 7:0            | R          | 0x0         | RF_CNT<br>RX FIFO Counter<br>These bits indicate the number of words in RX FIFO<br>0: 0 byte in RX FIFO<br>1: 1 byte in RX FIFO<br>...<br>64: 64 bytes in RX FIFO<br>other: Reserved |

### 9.3.6.7 0x0020 SPI Wait Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                       |
| 19:16          | R/W        | 0x0         | <p>SWC<br/>Dual mode direction switch wait clock counter (for master mode only).</p> <p>These bits control the number of wait states to be inserted before starting dual data transfer in dual SPI mode. The SPI module counts SPI_SCLK by SWC for delaying the next word data transfer.</p> <p>0: No wait states inserted<br/>n: n SPI_SCLK wait states inserted<br/>Cannot be written when XCH=1.</p> |
| 15:0           | R/W        | 0x0         | <p>WCC<br/>Wait Clock Counter (In master mode)</p> <p>These bits control the number of wait states to be inserted in data transfers. The SPI module counts SPI_SCLK by WCC for delaying the next word data transfer.</p> <p>0: No wait states inserted<br/>n: n SPI_SCLK wait states inserted<br/>Cannot be written when XCH=1.</p>                                                                     |

### 9.3.6.8 0x0028 SPI Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                                 |
| 15             | R/W        | 0x0         | <p>SAMP_DL_CAL_START<br/>Sample Delay Calibration Start<br/>When set, the sample delay chain calibration is started.<br/>Cannot be written when XCH=1.</p>                                                        |
| 14             | R          | 0x0         | <p>SAMP_DL_CAL_DONE<br/>Sample Delay Calibration Done<br/>When set, it means that sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.<br/>Cannot be written when XCH=1.</p> |

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                               |
| 13:8           | R          | 0x20        | <p>SAMP_DL<br/>Sample Delay<br/>It indicates the number of delay cells corresponding to the current card clock. The delay time generated by these delay cells is equal to the cycle of the card clock nearly.<br/>Generally, it is necessary to do drive delay calibration when the card clock is changed.<br/>This bit is valid only when SAMP_DL_CAL_DONE is set.<br/>Cannot be written when XCH=1.</p> |
| 7              | R/W        | 0x0         | <p>SAMP_DL_SW_EN<br/>Sample Delay Software Enable<br/>When set, it indicates that enable sample delay specified at SAMP_DL_SW.<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                      |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:0            | R/W        | 0x0         | <p>SAMP_DL_SW<br/>Sample Delay Software<br/>The relative delay between the clock line and command line, data lines.<br/>It can be determined according to the value of SAMP_DL, the cycle of the card clock, and the input timing requirement of the device.<br/>Cannot be written when XCH=1.</p>                                                                                                        |

### 9.3.6.9 0x0030 SPI Master Burst Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SPI_MBC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:24          | /          | /           | /                      |

| Offset: 0x0030 |            |             | Register Name: SPI_MBC                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                       |
| 23:0           | R/W        | 0x0         | <p>MBC<br/>Master Burst Counter<br/>In master mode, this field specifies the total burst number. The total transfer data include the TXD, RXD, and dummy burst.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |

### 9.3.6.10 0x0034 SPI Master Transmit Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SPI_MTC                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23:0           | R/W        | 0x0         | <p>MWTC<br/>Master Write Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy bursts. For saving bus bandwidth, the dummy bursts (all zero bits or all one bits) are sent by SPI Controller automatically.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |

### 9.3.6.11 0x0038 SPI Master Burst Control Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SPI_BCC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:30          | /          | /           | /                      |

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                              |
| 29             | R/W        | 0x0         | <p>Quad_EN<br/>Quad Mode Enable<br/>The quad mode includes Quad-Input and Quad-Output.<br/>0: Quad mode disable<br/>1: Quad mode enable<br/>Cannot be written when XCH=1.</p>                                                                                                                                                            |
| 28             | R/W        | 0x0         | <p>DRM<br/>Master Dual Mode_RX Enable<br/>It is only valid when Quad_Mode_EN=0.<br/>0: RX uses the single-bit mode<br/>1: RX uses the dual-bit mode<br/>Cannot be written when XCH=1.</p>                                                                                                                                                |
| 27:24          | R/W        | 0x0         | <p>DBC<br/>Master Dummy Burst Counter<br/>In master mode, this field specifies the burst number that should be sent before receiving in dual SPI mode. The data does not care by the device.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Cannot be written when XCH=1.</p>                                                 |
| 23:0           | R/W        | 0x0         | <p>STC<br/>Master Single Mode Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent in the single mode before automatically sending dummy bursts. This is the first transmit counter in all bursts.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Cannot be written when XCH=1.</p> |

## 9.3.6.12 0x0040 SPI Bit-Aligned Transfer Configure Register (Default Value: 0x0000\_00A0)

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31             | R/WAC      | 0x0         | <p>TCE<br/>Transfer Control Enable<br/>In master mode, it is used to start to transfer the serial bit frame, it is only valid when Work Mode Select==0x10/0x11.<br/>0: Idle<br/>1: Initiates transfer<br/>Writing “1” to this bit will start to transfer serial bit frame (the value comes from the SPI TX Bit Register or SPI RX Bit Register), and will auto-clear after the bursts transfer completely. Writing ‘0’ to this bit has no effect.</p> |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0: Delay Sample Mode<br/>1: Standard Sample Mode<br/>In Standard Sample Mode, the SPI master samples the data at the standard rising edge of SCLK for each SPI mode;<br/>In Delay Sample Mode, the SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p>                                                                      |
| 29:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in SPI TX Bit Register (or SPI RX Bit Register) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/>It is only valid when Work Mode Select==0x10/0x11.</p>                                                                                                                     |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/>It is only valid when Work Mode Select==0x10/0x11.</p>                                                                                                                                                                                                                                                                                                    |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 21:16          | R/W        | 0x00        | <p>Configure the length of serial data frame (burst) of RX</p> <p>000000: 0 bit<br/>000001: 1 bit<br/>...<br/>100000: 32 bits<br/>Other values: reserved</p> <p>It is only valid when Work Mode Select==0x10/0x11, and cannot be written when TCE (bit31) is 1.</p>                                                                                                                                                          |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13:8           | R/W        | 0x00        | <p>TX_FRM_LEN</p> <p>Configure the length of serial data frame (burst) of TX</p> <p>000000: 0 bit<br/>000001: 1 bit<br/>...<br/>100000: 32 bits<br/>Other values: reserved</p> <p>It is only valid when Work Mode Select==0x10/0x11, and cannot be written when TCE (bit31) is 1.</p>                                                                                                                                        |
| 7              | R/W        | 0x1         | <p>SS_LEVEL</p> <p>When control the SS signal manually, set this bit to '1' or '0' to control the level of SS signal.</p> <p>0: Set SS to low<br/>1: Set SS to high</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE (bit31) is 1.</p>                                                                                                                           |
| 6              | R/W        | 0x0         | <p>SS_OWNER</p> <p>SS Output Owner Select</p> <p>Usually, the controller sends the SS signal automatically with data together. When this bit is set to 1, the software must manually write SS_LEVEL to 1 or 0 to control the level of the SS signal.</p> <p>0: SPI controller<br/>1: Software</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE (bit31) is 1.</p> |

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                  |
| 5              | R/W        | 0x1         | <p>SPOL</p> <p>SPI Chip Select Signal Polarity Control</p> <p>0: Active high polarity (0 = Idle)</p> <p>1: Active low polarity (1 = Idle)</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE (bit31) is 1.</p>                                                                                                     |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                            |
| 3:2            | R/W        | 0x0         | <p>SS_SEL</p> <p>SPI Chip Select</p> <p>Select one of four external SPI Master/Slave Devices</p> <p>00: SPI_SS0 will be asserted</p> <p>01: SPI_SS1 will be asserted</p> <p>10: SPI_SS2 will be asserted</p> <p>11: SPI_SS3 will be asserted</p> <p>It is only valid when Work Mode Select= =0x10/0x11, and only work in Mode0, cannot be written when TCE (bit31) is 1.</p> |
| 1:0            | R/W        | 0x0         | <p>Work Mode Select</p> <p>00: Data frame is byte aligned in standard SPI, dual-output/dual input SPI, dual IO SPI, and quad-output/quad-input SPI</p> <p>01: Reserved</p> <p>10: Data frame is bit aligned in 3-wire SPI</p> <p>11: Data frame is bit aligned in standard SPI</p>                                                                                           |

### 9.3.6.13 0x0044 SPI Bit-Aligned CLOCK Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SPI_BA_CCR                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                  |
| 7:0            | R/W        | 0x0         | <p>CDR_N</p> <p>Clock Divide Rate (Master Mode Only)</p> <p>The SPI_SCLK is determined according to the following equation:<br/> <math>SPI\_CLK = Source\_CLK / (2 * (CDR_N + 1))</math>.</p> <p>This register is only valid when Work Mode Select==0x10/0x11.</p> |

### 9.3.6.14 0x0048 SPI TX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SPI_TBR                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | <p>VTB<br/>The Value of the Transmit Bits<br/>This register is used to store the value of the transmitted serial data frame.<br/>In the process of transmission, the LSB is transmitted first.<br/>This register is only valid when Work Mode Select==0x10/0x11.</p> |

### 9.3.6.15 0x004C SPI RX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | <p>VRB<br/>The Value of the Receive Bits<br/>This register is used to store the value of the received serial data frame.<br/>In the process of transmission, the LSB is transmitted first.<br/>This register is only valid when Work Mode Select==0x10/0x11.</p> |

### 9.3.6.16 0x0088 SPI Normal DMA Mode Control Register (Default Value: 0x0000\_00E5)

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                   |
| 7:6            | R/W        | 0x11        | <p>SPI_ACT_M<br/>SPI NDMA Active Mode<br/>00: dma_active is low<br/>01: dma_active is high<br/>10: dma_active is controlled by dma_request (DRQ)<br/>11: dma_active is controlled by controller</p> |
| 5              | R/W        | 0x1         | <p>SPI_ACK_M<br/>SPI NDMA Acknowledge Mode<br/>0: active fall do not care ack<br/>1: active fall must after detect ack is high</p>                                                                  |

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 4:0            | R/W        | 0x05        | SPI_DMA_WAIT<br>The counts of hold cycles from DMA last signal high to dma_active high |

### 9.3.6.17 0x0200 SPI TX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W        | 0x0         | TDATA<br>Transmit Data<br><br>This register can be accessed in the byte, half-word, or word unit by AHB. In the byte accessing method, if there are rooms in TXFIFO, one burst data is written to TXFIFO and the depth is increased by 1. In the half-word accessing method, two SPI burst data are written and the TXFIFO depth is increased by 2. In the word accessing method, four SPI burst data are written and the TXFIFO depth is increased by 4.<br><br><b>Note: This address is writable-only if TF_TEST is '0', and if TF_TEST is set to '1', this address is readable and writable to test the TXFIFO through the AHB bus.</b> |

## 9.3.6.18 0x0300 SPI RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: SPI_RXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R          | 0x0         | <p>RDATa<br/>Receive Data</p> <p>This register can be accessed in the byte, half-word, or word unit by AHB. In the byte accessing method, if there are data in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In the half-word accessing method, two SPI bursts are returned and the RXFIFO depth is decreased by 2. In the word accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.</p> <p><b>Note:</b> This address is readable-only if RF_TEST is '0', and if RF_TEST is set to '1', this address is readable and writable to test the RXFIFO through the AHB bus.</p> |

## 9.4 SPI\_DBI

### 9.4.1 Overview

The T113x provides a 3/4 line SPI display bus interface (SPI\_DBI) for video data transmission. It supports DBI mode or SPI mode. The DBI mode is compatible with multiple video data formats at the same time. The SPI mode is used for low-cost display schemes.

The SPI mode has the following features:

- Full-duplex synchronous serial interface
- Master/slave configurable
- 8-bit wide by 64-entry FIFO for both transmit and receive data
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable
- Supports interrupts and DMA
- Supports mode0, mode1, mode2, and mode3
- Supports 3-wire/4-wire SPI
- Supports programmable serial data frame length: 1 bit to 32 bits
- Supports standard SPI, dual-output/dual-input SPI, dual I/O SPI, quad-output/quad-input SPI
- Supports maximum IO rate of the mass production: 100 MHz

The DBI mode has the following features:

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

### 9.4.2 Block Diagram

Figure 9-30 shows a block diagram of the SPI\_DBI.

Figure 9-30 SPI\_DBI Block Diagram



SPI\_DBI contains the following sub-blocks:

Table 9-12 SPI\_DBI Sub-blocks

| Sub-block      | Description                                                                                                                                                                       |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| spi_rf         | Responsible for implementing the internal register, interrupt, and DMA Request.                                                                                                   |
| spi_tbuf       | The data length transmitted from AHB to TXFIFO is converted into 8 bits, then the data is written into the RXFIFO.                                                                |
| spi_rbuf       | The block is used to convert the RXFIFO data into the reading data length of AHB.                                                                                                 |
| txfifo, rxfifo | The data transmitted from the SPI to the external serial device is written into the TXFIFO; the data received from the external serial device into SPI is pushed into the RXFIFO. |
| spi_cmu        | Responsible for implementing SPI bus clock, chip select, internal sample, and the generation of transfer clock.                                                                   |
| spi_tx         | Responsible for implementing SPI data transfer, the interface of the internal TXFIFO, and status register.                                                                        |

| Sub-block | Description                                                                                                |
|-----------|------------------------------------------------------------------------------------------------------------|
| spi_rx    | Responsible for implementing SPI data receive, the interface of the internal RXFIFO, and status register.  |
| dbi_ctrl  | Responsible for implementing DBI bus clock, chip select, data command select, RGB format reshape.          |
| dbi_tx    | Responsible for implementing DBI data transfer, the interface of the internal TXFIFO, and status register. |
| dbi_rx    | Responsible for implementing DBI data receive, the interface of the internal RXFIFO, and status register.  |

### 9.4.3 Functional Description

#### 9.4.3.1 External Signals

The following table describes the external signals of SPI\_DBI. When using SPI\_DBI, the corresponding PADs are selected as SPI\_DBI function via section 9.7 “[GPIO](#)”.

**Table 9-13 SPI\_DBI External Signals**

| External Signal | Description | Type                                                                                                                                                     |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| DBI Mode        | DBI-CSX     | Chip select signal, low active                                                                                                                           |
|                 | DBI-SCLK    | Serial clock signal                                                                                                                                      |
|                 | DBI-SDO     | Data output signal                                                                                                                                       |
|                 | DBI-SDI     | Data input signal, the data is sampled on the rising edge and the falling edge                                                                           |
|                 | DBI-TE      | Tearing effect input, it is used to capture the external TE signal edge.                                                                                 |
|                 | DBI-DCX     | DCX pin is the select output signal of data and command.<br>DCX = 0: register command;<br>DCX = 1: data or parameter.                                    |
|                 | DBI-WRX     | When DBI operates in dual data lane format, the RGB666 format 2 can use WRX to transfer data                                                             |
| SPI Mode        | SPI1-CS     | SPI1 chip select signal, low active<br>When the device is not selected, data will not be accepted via the SI pin, and the SO pin will stop transmission. |
|                 | SPI1-CLK    | SPI1 clock signal<br>This pin is used to provide a clock to the device and is used to control the flow of data to and from the device.                   |
|                 | SPI1-MOSI   | SPI1 master data out, slave data in                                                                                                                      |

| External Signal |           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Type |
|-----------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|                 | SPI1-MISO | SPI1 master data in, slave data out                                                                                                                                                                                                                                                                                                                                                                                                                                  | I/O  |
|                 | SPI1-WP   | Write protection and active low<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode.                                                                                                                                                                                                                                                                                                                                      | I/O  |
|                 | SPI1-HOLD | When the device is selected and a serial sequence is underway, the HOLD pin is can be used to temporarily pause the serial communication with the master device without deselecting or resetting the device serial sequence. While the HOLD pin is asserted, the SO pin is at high impedance, and all transitions on the SCK pin and data on the SI pin are ignored.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode. | I/O  |

#### 9.4.3.2 Clock Sources

The SPI\_DBI controller gets 5 different clock sources, users can select one of them to make SPI\_DBI clock source. The following table describes the clock sources for SPI\_DBI. For more details on the clock setting, configuration, and gating information, see section 3.3 “[CCU](#)”.

**Table 9-14 SPI\_DBI Clock Sources**

| Clock Sources    | Description                                     |
|------------------|-------------------------------------------------|
| HOSC             | 24 MHz Crystal                                  |
| PLL_PERI(1X)     | Peripheral Clock, the default value is 600 MHz  |
| PLL_PERI(2X)     | Peripheral Clock, the default value is 1200 MHz |
| PLL_AUDIO0(DIV2) | Audio Clock, the default value is 1536 MHz      |
| PLL_AUDIO0(DIV5) | Audio Clock, the default value is 614.4 MHz     |

#### 9.4.3.3 Typical Application

Figure 9-31 shows the application block diagram when the SPI master device is connected to a slave device.

Figure 9-31 SPI Application Block Diagram



Figure 9-32 shows the application block diagram when the DBI master device is connected to a display bus interface device.

Figure 9-32 DBI Application Block Diagram



#### 9.4.3.4 SPI Transmission Format

The SPI supports 4 different formats for data transmission. The software can select one of the four modes in which the SPI works by setting the bit1 (Polarity) and bit0 (Phase) of [SPI\\_TCR](#). The SPI controller master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

The CPOL ([SPI\\_TCR\[1\]](#)) defines the polarity of the clock signal (SPI\_SCLK). The SPI\_SCLK is a high level when CPOL is '1' and it is a low level when CPOL is '0'. The CPHA ([SPI\\_TCR\[0\]](#)) decides whether the leading edge of SPI\_SCLK is used to setup or sample data. The leading edge is used to setup data when CPHA is '1', and sample data when CPHA is '0'. The following table lists the four modes.

**Table 9-15 SPI Transmit Format**

| SPI Mode | Polarity (CPOL) | Phase (CPHA) | Leading Edge               | Trailing Edge              |
|----------|-----------------|--------------|----------------------------|----------------------------|
| mode0    | 0               | 0            | Sample on the rising edge  | Setup on the falling edge  |
| mode1    | 0               | 1            | Setup on the rising edge   | Sample on the falling edge |
| mode2    | 1               | 0            | Sample on the falling edge | Setup on the rising edge   |
| mode3    | 1               | 1            | Setup on the falling edge  | Sample on the rising edge  |

Figure 9-33 and Figure 9-34 describe four waveforms for SPI\_SCLK.

**Figure 9-33 SPI Phase 0 Timing Diagram****Figure 9-34 SPI Phase 1 Timing Diagram**

#### 9.4.3.5 SPI Master and Slave Mode

The SPI controller can be configured to a master or slave device. The master mode is selected by setting the MODE bit ([SPI\\_GCR\[1\]](#)); the slave mode is selected by clearing the MODE bit.

In master mode, the SPI\_CLK is generated and transmitted to the external device, and the data from the TX FIFO is transmitted on the MOSI pin, the data from the slave is received on the MISO pin and sent to RX FIFO. The Chip Select (SPI\_SS) is an active low signal, and it must be set low before the data are transmitted or received. The SPI\_SS can be selected the auto control mode or the software manual control mode. When using auto control, the SS\_OWNER ([SPI\\_TCR\[6\]](#)) must be cleared (default value is 0); when using manual control, the SS\_OWNER must be set. And the level of SPI\_SS is controlled by SS\_LEVEL ([SPI\\_TCR\[7\]](#)).

In slave mode, after the software selects the MODE bit ([SPI\\_GCR\[1\]](#)) to '0', it waits for master initiate a transaction. When the master asserts SPI\_SS, and SPI\_CLK is transmitted to the slave, the slave data is transmitted from TX FIFO on the MISO pin, and the data from the MOSI pin is received in RX FIFO.

#### 9.4.3.6 SPI 3-Wire Mode

The SPI 3-wire mode is only valid when the SPI controller work in master mode, and is selected when the Work Mode Select bit ([SPI\\_BATC\[1:0\]](#)) is equal to 0x2. And in the 3-wire mode, the input data and the output data use the same single data line. The following figure describes the 3-wire mode.

Figure 9-35 SPI 3-Wire Mode



#### 9.4.3.7 SPI Dual-Input/Dual-Output and Dual I/O Mode

The dual read mode (SPI x2) is selected when the DRM is set in [SPI\\_BCC\[28\]](#). Using the dual mode allows data to be transferred to or from the device at double the rate of standard single mode SPI devices, the data can be read at fast speed using two data bits (MOSI and MISO) at a time. The following figure describes the dual-input/dual-output SPI (Figure 9-36) and the dual I/O SPI (Figure 9-37).

Figure 9-36 SPI Dual-Input/Dual-Output Mode



In the dual-input/dual-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line, only the data bytes are output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

Figure 9-37 SPI Dual I/O Mode



In the dual I/O SPI mode, only the command bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. The address bytes and the dummy bytes output in a unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

#### 9.4.3.8 SPI Quad-Input/Quad-Output Mode

The quad read mode (SPI x4) is selected when the Quad\_EN is set in [SPI\\_BCC](#)[29]. Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode SPI devices, the data can be read at fast speed using four data bits (MOSI, MISO, IO2 (WP#) and IO3 (HOLD#)) at the same time. The following figure describes the quad-input/quad-output SPI.

**Figure 9-38 SPI Quad-Input/Quad-Output Mode**



In the quad-input/quad-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. Only the data bytes output (write) and input (read) in a unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP#, and SPI\_HOLD#.

#### 9.4.3.9 Transmission/Reception Bursts in Master Mode

In SPI master mode, the transmission and reception bursts (byte in unit) are configured before the SPI transfers serial data between the processor and external device. The transmission bursts are written in MWTC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). The transmission bursts in single mode before automatically sending dummy bursts are written in STC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). For dummy data, the SPI controller can automatically send before receiving by writing DBC (bit[27:24]) in the [SPI Master Transmit Counter Register](#). If users do not use the SPI controller to send dummy data automatically, then the dummy bursts are used as the transmission counters to write together in MWTC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). In master mode, the total burst numbers are written in MBC (bit[23:0]) of the [SPI Master Transmit Counter Register](#). When all transmission and reception bursts are transferred, the SPI controller will send a completed interrupt, at the same time, the SPI controller will clear DBC, MWTC, and MBC.

#### 9.4.3.10 SPI Sample Mode and Run Clock Configuration

The SPI controller runs at 3 kHz–100 MHz at its interface to external SPI devices. The internal SPI clock should run at the same frequency as the outgoing clock in the master mode. The SPI clock is selected from different clock sources, the SPI must configure different work mode. There are three work modes: normal sample mode, delay half-cycle sample mode, delay one-cycle sample mode. Delay half-cycle sample mode is the default mode of the SPI controller. When the SPI runs at 40 MHz or below 40 MHz, the SPI can work at normal sample mode or delay half-cycle sample mode. When the SPI runs over 80 MHz, setting the SDC bit in the [SPI Transfer Control Register](#) to '1' makes the internal read sample point with a half-cycle delay of SPI\_CLK, which is used in high speed read operation to reduce the error caused by the time delay of SPI\_CLK between master and slave. Table 9-16 and Table 9-17 show the different configurations of the SPI sample mode.

**Table 9-16 SPI Old Sample Mode and Run Clock**

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | Run Clock |
|-------------------------|------------|------------|-----------|
| normal sample           | 1          | 0          | <=24 MHz  |
| delay half cycle sample | 0          | 0          | <=40 MHz  |
| delay one cycle sample  | 0          | 1          | >=80 MHz  |



**CAUTION**

The remaining spectrum is not recommended. Because when the output delay of SPI flash (refer to the datasheet of the manufacturer for the specific delay time) is the same with the half-cycle time of SPI working clock, the variable edge of the output data for the device bumps into the clock sampling edge of the controller, so setting 1 cycle of sampling delay would cause stability problem.

**Table 9-17 SPI New Sample Mode**

| SPI Sample Mode         | SDM (bit13) | SDC (bit11) | SDC1 (bit15) |
|-------------------------|-------------|-------------|--------------|
| normal sample           | 1           | 0           | 0            |
| delay half cycle sample | 0           | 0           | 0            |
| delay one cycle sample  | 0           | 1           | 0            |
| delay 1.5 cycle sample  | 1           | 1           | 0            |
| delay 2 cycle sample    | 1           | 0           | 1            |
| delay 2.5 cycle sample  | 0           | 0           | 1            |
| delay 3 cycle sample    | 0           | 1           | 1            |

#### 9.4.3.11 DBI 3-Line Interface Writing and Reading Timing

The 3-line DBI Interface I contains CSX, SDA, and SCL, where SDA shares this port for bidirectional port data input and output.

The 3-line DBI Interface II contains CSX, SDA, SCL, and SDI; Data input and output ports are independent of each other.

Since the 3-line display bus mode has no Data/Command data line indicating whether Data or Command is currently being transmitted, an extra bit is added to the data-stream before MSB to indicate whether Data or Command is currently being transmitted. (0: Command, 1: Data)

The following figure shows the writing operation format of 3-line DBI Interface I and Interface II.

Figure 9-39 DBI 3-Line Display Bus Serial Interface Writing Operation Format



The 3-line DBI Interface I uses the SDA port as bidirectional data input and output port. There are only three cases of data reading volume, 8bits/24bits/32bits, and the first data sampled is high.

The following figure shows the 8 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read immediately with on dummy period.

**Figure 9-40 DBI 3-Line Display Bus Serial Interface 8-bit Reading Operation Format**

The following figure shows the 24 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read after waiting for the dummy clock cycle.

**Figure 9-41 DBI 3-Line Display Bus Serial Interface 24-bit Reading Operation Format**

The following figure shows the 32 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read after waiting for the dummy clock cycle.

**Figure 9-42 DBI 3-Line Display Bus Serial Interface 32-bit Reading Operation Format**

#### 9.4.3.12 DBI 4-Line Interface Writing and Reading Timing

The 4-line DBI Interface I contains CSX, D/CX, SDA, and SCL, where SDA shares this port for bidirectional port data input and output.

The 4-line DBI Interface II contains CSX, D/CX, SDA, SCL, and SDI; Data input and output ports are independent of each other.

Since the 4-line display bus mode has a Data/Command data line indicating whether Data or Command is currently being transmitted (0: Command, 1: Data). So there is no need to add an extra bit to data-stream before MSB like the 3-line DBI.

The following figure shows the writing operation format of 4-line DBI Interface I and Interface II.

**Figure 9-43 DBI 4-Line Display Bus Serial Interface Writing Operation Format**

The following figure shows the 8 bits reading operation format of 4-line DBI Interface I and Interface II.

**Figure 9-44 DBI 4-Line Display Bus Serial Interface 8-bit Reading Operation Format**

The following figure shows the 24 bits reading operation format of 4-line DBI Interface I and Interface II.

**Figure 9-45 DBI 4-Line Display Bus Serial Interface 24-bit Reading Operation Format**

The following figure shows the 32 bits reading operation format of 4-line DBI Interface I and Interface II.

**Figure 9-46 DBI 4-Line Display Bus Serial Interface 32-bit Reading Operation Format**

#### 9.4.3.13 DBI 3-Line Interface Transmit Video Format

Figure 9-47 RGB111 3-Line Interface Transmit Video Format



Figure 9-48 RGB444 3-Line Interface Transmit Video Format



**Figure 9-49 RGB565 3-Line Interface Transmit Video Format**

**Figure 9-50 RGB666 3-Line Interface Transmit Video Format**


#### 9.4.3.14 DBI 4-Line Interface Transmit Video Format

Figure 9-51 RGB111 4-Line Interface Transmit Video Format



Figure 9-52 RGB444 4-Line Interface Transmit Video Format



Note 1. Pixel data with 12-bit color depth information

Note 2. The most significant bits are: Rx3, Gx3 and Bx3

Note 3. The least significant bits are: Rx0, Gx0 and Bx0

**Figure 9-53 RGB565 4-Line Interface Transmit Video Format**

**Figure 9-54 RGB666 4-Line Interface Transmit Video Format**


#### 9.4.3.15 DBI 2 Data Lane Interface Transmit Video Format

For RGB444:

Figure 9-55 RGB444 2 Data Lane Interface Transmit Video Format



Figure 9-56 RGB565 2 Data Lane Interface Transmit Video Format



Figure 9-57 RGB666 2 Data Lane Interface Transmit Video Format 0



Figure 9-58 RGB666 2 Data Lane Interface Transmit Video Format 1 (ilitek)



Figure 9-59 RGB666 2 Data Lane Interface Transmit Video Format 2 (New vision)



Figure 9-60 RGB888 2 Data Lane Interface Transmit Video Format

## RGB888



Note 1. Pixel data with 24-bit color information

Note 2. The most significant bits are: R7, G7 and B7

Note 3. The least significant bits are: R0, G0 and B0

## 9.4.4 Programming Guidelines

### 9.4.4.1 Writing/Reading Data Process Using SPI Mode

The SPI transfers serial data between the processor and the external device. CPU and DMA are the two main operational modes for SPI. For each SPI, the data is simultaneously transmitted (shifted out serially) and received (shifted in serially). The SPI has 2 channels, including the TX channel and RX channel. The TX channel has the path from TX FIFO to the external device. The RX channel has the path from the external device to RX FIFO.

**Write Data:** CPU or DMA must write data on the [SPI\\_TXD](#) register, the data on the register are automatically moved to TX FIFO.

**Read Data:** To read data from RX FIFO, CPU or DMA must access the register [SPI\\_RXD](#) and data are automatically sent to the register [SPI\\_RXD](#).

In CPU or DMA mode, the SPI sends a completed interrupt ([SPI\\_ISR\[TC\]](#)) to the processor at the end of each transfer.

**CPU Mode****Figure 9-61 SPI Write/Read Data in CPU Mode**

**DMA Mode****Figure 9-62 SPI Write/Read Data in DMA Mode**

#### 9.4.4.2 Calibrate Delay Chain Using SPI Mode

The SPI has one delay chain which is used to generate delay to make proper timing between the internal SPI clock signal and data signals. Delay chain is made up of 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

The steps to calibrate delay chain are as follows:

- Step 1** Enable SPI. To calibrate the delay chain by operation registers in SPI, the SPI must be enabled through AHB reset and AHB clock gating control registers.
- Step 2** Configure a proper clock for SPI. The calibration delay chain is based on the clock for SPI from CCU.
- Step 3** Set proper initial delay value. Write 0xA0 to the [SPI Sample Delay Control Register](#) to set initial delay value 0x20 to delay chain. Then write 0x0 to the [SPI Sample Delay Control Register](#) to clear this value.
- Step 4** Write 0x8000 to the [SPI Sample Delay Control Register](#) to start to calibrate the delay chain.
- Step 5** Wait until the flag (Bit14 in the [SPI Sample Delay Control Register](#)) of calibration done is set. The number of delay cells is shown at Bit[13:8] in [SPI Sample Delay Control Register](#). The delay time generated by these delay cells is equal to the cycle of SPI's clock nearly. This value is the result of calibration.
- Step 6** Calculate the delay time of one delay cell according to the cycle of the SPI clock and the result of calibration.

#### 9.4.4.3 Transmitting Write Command Using DBI Mode

- Step 1** Set the [SPI DBI MODE SEL](#) (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.
- Step 2** Set the [DBI EN MODE SEL](#) (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 0 to select the trigger mode of DBI.
- Step 3** Configure the [DBI\\_CTL\\_0](#) (0x0100).
  - Set [DBI\\_CTL\\_0\[Command Type\]](#) (bit31) to 0 to configure the writing command.
  - Set [DBI\\_CTL\\_0\[Write Command Dummy Cycles\]](#) (bit[30:20]) to configure the number of dummy cycles between commands.
  - Set [DBI\\_CTL\\_0\[Output Data Sequence\]](#) (bit19) to select the MSB or LSB.
  - Set [DBI\\_CTL\\_0\[Transmit Mode\]](#) (bit15) to 0 to select the command path.
  - Set [DBI\\_CTL\\_0\[Output Data Format\]](#) (bit[14:12]) to 0 to transmit the command.
  - Set [DBI\\_CTL\\_0\[DBI interface Select\]](#) (bit[10:8]) to select the DBI interface type.
  - The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 0 to send the command.

**Step 5** DMA Path: Configure the [SPI\\_FCR](#) register (0x0018).

➤ Set [SPI\\_FCR](#)[TF\_DRQ\_EN] (bit24) to 1 to enable TXFIFO DMA.

➤ Set [SPI\\_FCR](#)[TX\_TRIG\_LEVEL] (bit[23:16]) to 255. It indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 255.

CPU Path: Write the command to be sent to the 0x200 address.

**Step 6** Set [SPI\\_GCR](#)[DBI\_EN] (bit4) to 1 to start transmitting the command.

**Step 7** Wait until the TX FIFO underrun interrupt ([SPI\\_ISR](#)[TF\_UDF]) is 1. It indicates that the command written to the TX FIFO is transmitted completely.

#### 9.4.4.4 Transmitting Parameter Using DBI Mode

**Step 1** Set the [SPI\\_DBI\\_MODE\\_SEL](#) (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the [DBI\\_EN\\_MODE\\_SEL](#) (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 0 to select the trigger mode of DBI.

**Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).

➤ Set [DBI\\_CTL\\_0](#)[Command Type] (bit31) to 0 to configure the writing command.

➤ Set [DBI\\_CTL\\_0](#)[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.

➤ Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.

➤ Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 0 to select the command path.

➤ Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to 0 to transmit the command.

➤ Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.

➤ The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 1 to send the parameter.

**Step 5** DMA Path: Configure the [C:\Users\zengjing\Downloads\ Hlk49435465 - Hlk49435792](#) register (0x0018).

➤ Set [SPI\\_FCR](#)[TF\_DRQ\_EN] (bit24) to 1 to enable TXFIFO DMA.

➤ Set [SPI\\_FCR](#)[TX\_TRIG\_LEVEL] (bit[23:16]) to 255. It indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 255.

CPU Path: Write the command to be sent to the 0x0200 address.

**Step 6** Set [SPI\\_GCR](#)[DBI\_EN] (bit4) to 1 to start transmitting the command.

**Step 7** Wait until the TX FIFO underrun interrupt ([SPI\\_ISR\[TF\\_UDF\]](#)) is 1. It indicates that the command written to the TX FIFO is transmitted completely.

#### 9.4.4.5 Transmitting Video Using DBI Mode

Set the [SPI\\_DBI\\_MODE\\_SEL](#) (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

If the data is from the CPU path, the controller writes the command to be sent to the 0x0200 address by the AHB bus.

If the data is from the DMA path, configure [DBI\\_CTL\\_1\[DBI\\_FIFO\\_DRQ\\_EN\]](#) (bit15) to 1 and [DBI\\_CTL\\_1\[TX\\_TRIG\\_LEVEL\]](#) (bit[14:8]) to 64, which indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 64.

##### Software Trigger Mode

The software enables DBI\_en\_trigger when the edge interrupt of TE is detected.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt and stops transmitting data.

Wait for the edge interrupt of TE, the software needs to enable DBI\_en\_trigger, in circulation.

The operation process is as follows.

**Step 1** Set the [SPI\\_DBI\\_MODE\\_SEL](#) (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the [DBI\\_EN\\_MODE\\_SEL](#) (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 1 to select the software trigger mode.

**Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).

- Set [DBI\\_CTL\\_0\[Command Type\]](#) (bit31) to 0 to set the writing command.
- Set [DBI\\_CTL\\_0\[Write Command Dummy Cycles\]](#) (bit[30:20]) to configure the number of dummy cycles between commands.
- Set [DBI\\_CTL\\_0\[Output Data Sequence\]](#) (bit19) to select the MSB or LSB.
- Set [DBI\\_CTL\\_0\[Transmit Mode\]](#) (bit15) to 1 to select the image path.
- Set [DBI\\_CTL\\_0\[Output Data Format\]](#) (bit[14:12]) to select RGB111//444/565/666/888.
- Set [DBI\\_CTL\\_0\[DBI interface Select\]](#) (bit[10:8]) to select the DBI interface type.
- The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1\[DCX\\_DATA\]](#) (bit22) to 0 to send the image data.

**Step 5** Configure [DBI\\_Video\\_Size](#) (0x110) according to the sent image size.

**Step 6** Configure **DBI\_CTL\_2** (0x0108) to set the TE-related parameter.

**Step 7** Detect the TE interrupt of the **DBI\_INT** (0x0120) register.

**Step 8** Configure **DBI\_CTL\_1[DBI\_soft\_trigger]** to 1.

### Timer Trigger Mode

The software configures timer\_en to enable timer counting, and when the counter reaches the specified value, the DBI\_EN automatically can be enabled to start transmitting data.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt, and stops transmitting data.

The timer starts counting again. When the counter reaches the specified value, the controller automatically enables DBI\_EN, and in circulation until the software turns off the timer\_en.

The operation process is as follows.

**Step 1** Set the **SPI\_DBI\_MODE\_SEL** (bit3) of **SPI\_GCR** (0x0004) to 1 to select DBI mode.

**Step 2** Set the **DBI\_EN\_MODE\_SEL** (bit30:29) of **DBI\_CTL\_1** (0x0104) to 2 to select the timer trigger mode.

**Step 3** Configure the **DBI\_CTL\_0** register (0x0100).

- Set **DBI\_CTL\_0[Command Type]** (bit31) to 0 to set the writing command.
- Set **DBI\_CTL\_0[Write Command Dummy Cycles]** (bit[30:20]) to configure the number of dummy cycles between commands.
- Set **DBI\_CTL\_0[Output Data Sequence]** (bit19) to select the MSB or LSB.
- Set **DBI\_CTL\_0[Transmit Mode]** (bit15) to 1 to select the image path.
- Set **DBI\_CTL\_0[Output Data Format]** (bit[14:12]) to select RGB111/444/565/666/888.
- Set **DBI\_CTL\_0[DBI interface Select]** (bit[10:8]) to select the DBI interface type.
- The remaining values of the **DBI\_CTL\_0** register remain the default value.

**Step 4** Set **DBI\_CTL\_1[DCX\_DATA]** (bit22) to 0 to send the image data.

**Step 5** Configure **DBI\_Video\_Size** (0x110) to transmit the image size.

**Step 6** Configure the related parameter of **DBI\_Timer** (0x10C).

### TE Trigger Mode

When the edge changes of the TE are detected (The rising and falling edges are optional), the DBI\_EN automatically can be enabled to start transmitting data.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt, and stops transmitting data.

When the edge changes of the TE are detected (The rising and falling edges are optional), the DBI\_EN automatically can be enabled to start transmitting data until the software shuts down TE\_EN or the screen no longer sends TE signals.

The operation process is as follows.

**Step 1** Set the SPI DBI MODE SEL (bit3) of SPI GCR (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit30:29) of DBI CTL 1 (0x0104) to 3 to select the TE trigger mode.

**Step 3** Configure the DBI CTL 0 register (0x0100).

- Set DBI CTL 0[Command Type] (bit31) to 0 to set the writing command.
- Set DBI CTL 0[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.
- Set DBI CTL 0[Output Data Sequence] (bit19) to select the MSB or LSB.
- Set DBI CTL 0[Transmit Mode] (bit15) to 1 to select the image path.
- Set DBI CTL 0[Output Data Format] (bit[14:12]) to select RGB111/444/565/666/888.
- Set DBI CTL 0[DBI interface Select] (bit[10:8]) to select the DBI interface type.
- The remaining values of the DBI CTL 0 register remain the default value.

**Step 4** Configure DBI CTL 1[DCX\_DATA] (bit22) to 0 to send the image data.

**Step 5** Configure DBI Video Size (0x0110) to transmit the image size.

**Step 6** Configure DBI CTL 2 (0x0108) to set the TE-related parameter.

#### 9.4.4.6 Transmitting Read Command and Read Data Using DBI Mode

**Step 1** Set the SPI DBI MODE SEL (bit3) of SPI GCR (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit[30:29]) of DBI CTL 1 (0x0104) to 0.

**Step 3** Configure the DBI CTL 0 register (0x0100).

- Set DBI CTL 0[Command Type] (bit31) to 0 to set the reading command.
- Set DBI CTL 0[Output Data Sequence] (bit19) to select the MSB or LSB.
- Set DBI CTL 0[Transmit Mode] (bit15) to 0 to select the command path.
- Set DBI CTL 0[Output Data Format] (bit[14:12]) to 0.
- Set DBI CTL 0[DBI interface Select] (bit[10:8]) to select the DBI interface type.

- The remaining values of the **DBI\_CTL\_0** register remain the default value.

**Step 4** Configure the **DBI\_CTL\_1** register (0x0104).

- Configure **DBI\_CTL\_1[DCX\_DATA]** (bit22) to 0 to send the command.
- Configure **DBI\_CTL\_1[Read\_MSB\_First]** (bit20) to select whether the first bit of the read data is the highest or lowest bit of data.
- Configure **DBI\_CTL\_1[Read Data Number of Bytes]** to set the byte number to be read.
- Configure **DBI\_CTL\_1[Read Command Dummy Cycles]** to set the dummy cycle between the read command and the read data, when the dummy cycle is complete, the data starts to be sampled.

**Step 5** DMA Path: Configure the **SPI\_FCR** register (0x0018).

- Set **SPI\_FCR[RF\_DRQ\_EN]** (bit8) to 1 to enable RXFIFO DMA.
- Set **SPI\_FCR[RX\_TRIG\_LEVEL]** (bit[7:0]) to 32, which indicates the controller requests receiving data from DMA if the data of the RX FIFO is greater than 64.

CPU Path: Read data in RX FIFO from the 0x0300 address.

**Step 6** Set **SPI\_GCR[DBI\_EN]** (bit4) to 1 to start transmitting command.

**Step 7** Wait until **DBI\_INT[RD\_DONE\_INT]** is 1. It indicates that the data is read completely.

#### 9.4.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI_DBI     | 0x04026000   |

| Register Name | Offset | Description                          |
|---------------|--------|--------------------------------------|
| SPI_GCR       | 0x0004 | SPI Global Control Register          |
| SPI_TCR       | 0x0008 | SPI Transfer Control Register        |
| SPI_IER       | 0x0010 | SPI Interrupt Control Register       |
| SPI_ISR       | 0x0014 | SPI Interrupt Status Register        |
| SPI_FCR       | 0x0018 | SPI FIFO Control Register            |
| SPI_FSR       | 0x001C | SPI FIFO Status Register             |
| SPI_WCR       | 0x0020 | SPI Wait Clock Register              |
| SPI_SAMP_DL   | 0x0028 | SPI Sample Delay Control Register    |
| SPI_MBC       | 0x0030 | SPI Master Burst Counter Register    |
| SPI_MTC       | 0x0034 | SPI Master Transmit Counter Register |

| Register Name     | Offset | Description                                  |
|-------------------|--------|----------------------------------------------|
| SPI_BCC           | 0x0038 | SPI Master Burst Control Register            |
| SPI_BATCR         | 0x0040 | SPI Bit-Aligned Transfer Configure Register  |
| SPI_BA_CCR        | 0x0044 | SPI Bit-Aligned Clock Configuration Register |
| SPI_TBR           | 0x0048 | SPI TX Bit Register                          |
| SPI_RBR           | 0x004C | SPI RX Bit Register                          |
| SPI_NDMA_MODE_CTL | 0x0088 | SPI Normal DMA Mode Control Register         |
| DBI_CTL_0         | 0x0100 | DBI Control Register 0                       |
| DBI_CTL_1         | 0x0104 | DBI Control Register 1                       |
| DBI_CTL_2         | 0x0108 | DBI Control Register 2                       |
| DBI_TIMER         | 0x010C | DBI Timer Control Register                   |
| DBI_VIDEO_SZIE    | 0x0110 | DBI Video Size Configuration Register        |
| DBI_INT           | 0x0120 | DBI Interrupt Register                       |
| DBI_DEBUG_0       | 0x0124 | DBI BEBUG 0 Register                         |
| DBI_DEBUG_1       | 0x0128 | DBI BEBUG 1 Register                         |
| SPI_TXD           | 0x0200 | SPI TX Data register                         |
| SPI_RXD           | 0x0300 | SPI RX Data register                         |

#### 9.4.6 Register Description

##### 9.4.6.1 0x0004 SPI Global Control Register (Default Value: 0x0000\_0080)

| Offset:0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                       |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31            | R/WAC      | 0x0         | SRST<br>Soft reset<br>Writing '1' to this bit will clear the SPI controller, and auto clear to '0' when reset operation completes.<br>Writing '0' to this bit has no effect. |
| 30:8          | /          | /           | /                                                                                                                                                                            |

| Offset:0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                                                                                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                          |
| 7             | R/W        | 0x1         | <p>TP_EN<br/>Transmit Pause Enable<br/>In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br/>0: Normal operation, ignore RXFIFO status<br/>1: Stop transmit data when RXFIFO full<br/>Cannot be written when XCH=1.</p> |
| 6:5           | /          | /           | /                                                                                                                                                                                                                                                                                    |
| 4             | R/W        | 0x0         | <p>DBI EN<br/>DBI Module Enable Control<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                             |
| 3             | R/W        | 0x0         | <p>SPI_DBI_MODE_SEL<br/>DBI Working Mode Select<br/>0: SPI MODE<br/>1: DBI MODE</p>                                                                                                                                                                                                  |
| 2             | R/W        | 0x0         | <p>MODE_SELEC<br/>Sample Timing Mode Select<br/>0: Old mode of Sample Timing<br/>1: New mode of Sample Timing<br/>Cannot be written when XCH=1.</p>                                                                                                                                  |
| 1             | R/W        | 0x0         | <p>MODE<br/>SPI Function Mode Select<br/>0: Slave mode<br/>1: Master mode<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                      |
| 0             | R/W        | 0x0         | <p>EN<br/>SPI Module Enable Control<br/>0: Disable<br/>1: Enable<br/>After transforming from bit_mode to byte_mode, it must enable the SPI module again.</p>                                                                                                                         |

## 9.4.6.2 0x0008 SPI Transfer Control Register (Default Value: 0x0000\_0087)

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31             | R/WAC      | 0x0         | <p>XCH</p> <p>Exchange Burst</p> <p>In master mode, it is used to start SPI burst</p> <p>0: Idle</p> <p>1: Initiates exchange.</p> <p>Writing “1” to this bit will start the SPI burst, and will auto-clear after finishing the bursts transfer specified by BC. Writing “1” to SRST will also clear this bit. Writing ‘0’ to this bit has no effect.</p> <p>Cannot be written when XCH=1.</p>                                                         |
| 30:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15             | R/W        | 0x0         | <p>SDC1</p> <p>Master Sample Data Control register1</p> <p>Set this bit to ‘1’ to make the internal read sample point with a delay of half-cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK between master and slave.</p> <p>0: Normal operation, do not delay the internal read sample point</p> <p>1: Delay the internal read sample point</p> <p>Cannot be written when XCH=1.</p> |
| 14             | R/W        | 0x0         | <p>SDDM</p> <p>Sending Data Delay Mode</p> <p>0: Normal sending</p> <p>1: Delay sending</p> <p>Set the bit to "1" to make the data that should be sent with a delay of half-cycle of SPI_CLK in dual IO mode for SPI mode 0.</p> <p>Cannot be written when XCH=1.</p>                                                                                                                                                                                  |
| 13             | R/W        | 0x0         | <p>SDM</p> <p>Master Sample Data Mode</p> <p>0: Delay sample mode</p> <p>1: Normal sample mode</p> <p>In normal sample mode, the SPI master samples the data at the correct edge for each SPI mode;</p> <p>In delay sample mode, the SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.</p> <p>Cannot be written when XCH=1.</p>                                                       |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12             | R/W        | 0x0         | <p>FBS<br/>First Transmit Bit Select<br/>0: MSB first. The upper bits are transmitted first.<br/>1: LSB first. The lower bits are transmitted first.<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                   |
| 11             | R/W        | 0x0         | <p>SDC<br/>Master Sample Data Control<br/>Set this bit to '1' to make the internal read sample point with a delay of half-cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK between master and slave.<br/>0: Normal operation, do not delay the internal read sample point<br/>1: Delay the internal read sample point<br/>Cannot be written when XCH=1.</p> |
| 10             | R/W        | 0x0         | <p>RPSM<br/>Rapids Mode Select<br/>Select rapid mode for high speed write.<br/>0: Normal write mode<br/>1: Rapid write mode<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                                            |
| 9              | R/W        | 0x0         | <p>DDB<br/>Dummy Burst Type<br/>0: The bit value of dummy SPI burst is zero<br/>1: The bit value of dummy SPI burst is one<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                                             |
| 8              | R/W        | 0x0         | <p>DHB<br/>Discard Hash Burst<br/>In master mode, it controls whether discarding unused SPI bursts<br/>0: Receiving all SPI bursts in the BC period<br/>1: Discard unused SPI bursts, only fetching the SPI bursts during the dummy burst period. The burst number is specified by TC.<br/>Cannot be written when XCH=1.</p>                                                                                                 |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 7              | R/W        | 0x1         | <p>SS_LEVEL<br/>SPI Chip Select Level<br/>When control SS signal manually (SS_OWNER (SPI_TCR[6]) == 1), set this bit to '1' or '0' to control the level of SS signal.<br/>0: Set SS to low<br/>1: Set SS to high<br/>Cannot be written when XCH=1.</p>                                                                                  |
| 6              | R/W        | 0x0         | <p>SS_OWNER<br/>SS Output Owner Select<br/>Usually, the controller sends the SS signal automatically with data together. When this bit is set to 1, the software must manually write SS_LEVEL (SPI_TCR[7]) to 1 or 0 to control the level of the SS signal.<br/>0: SPI controller<br/>1: Software<br/>Cannot be written when XCH=1.</p> |
| 5:4            | R/W        | 0x0         | <p>SS_SEL<br/>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted<br/>10: SPI_SS2 will be asserted<br/>11: SPI_SS3 will be asserted<br/>Cannot be written when XCH=1.</p>                                                                        |
| 3              | R/W        | 0x0         | <p>SSCTL<br/>In master mode, this bit selects the output waveform for the SPI_SSx signal. Only valid when SS_OWNER (SPI_TCR[6]) = 0.<br/>0: SPI_SSx remains asserted between SPI bursts<br/>1: Negate SPI_SSx between SPI bursts<br/>Cannot be written when XCH=1.</p>                                                                  |
| 2              | R/W        | 0x1         | <p>SPOL<br/>SPI Chip Select Signal Polarity Control<br/>0: Active high polarity (0 = Idle)<br/>1: Active low polarity (1 = Idle)<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                  |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
| 1              | R/W        | 0x1         | CPOL<br>SPI Clock Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br>Cannot be written when XCH=1.                 |
| 0              | R/W        | 0x1         | CPHA<br>SPI Clock/Data Phase Control<br>0: Phase 0 (Leading edge for sample data)<br>1: Phase 1 (Leading edge for setup data)<br>Cannot be written when XCH=1. |

#### 9.4.6.3 0x0010 SPI Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:14          | /          | /           | /                                                                                                                                  |
| 13             | R/W        | 0x0         | SS_INT_EN<br>SSI Interrupt Enable<br>Chip select signal (SSx) from the valid state to the invalid state<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | TC_INT_EN<br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                        |
| 11             | R/W        | 0x0         | TF_UDR_INT_EN<br>TXFIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable                                                       |
| 10             | R/W        | 0x0         | TF_OVF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable                                                      |

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 9              | R/W        | 0x0         | RF_UDR_INT_EN<br>RX FIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable      |
| 8              | R/W        | 0x0         | RF_OVF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 7              | /          | /           | /                                                                                  |
| 6              | R/W        | 0x0         | TF_FUL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 5              | R/W        | 0x0         | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4              | R/W        | 0x0         | TX_ERQ_INT_EN<br>TX FIFO Empty Request Interrupt Enable<br>0: Disable<br>1: Enable |
| 3              | /          | /           | /                                                                                  |
| 2              | R/W        | 0x0         | RF_FUL_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 1              | R/W        | 0x0         | RX_EMP_INT_EN<br>RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 0              | R/W        | 0x0         | RF_RDY_INT_EN<br>RX FIFO Ready Request Interrupt Enable<br>0: Disable<br>1: Enable |

## 9.4.6.4 0x0014 SPI Interrupt Status Register (Default Value: 0x0000\_0032)

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 13             | R/W1C      | 0x0         | <p>SSI<br/>SS Invalid Interrupt<br/>When SSI is 1, it indicates that SS has changed from the valid state to the invalid state. Writing 1 to this bit clears it.</p>                                                                                                                                                                                                     |
| 12             | R/W1C      | 0x0         | <p>TC<br/>Transfer Completed<br/>In master mode, it indicates that all bursts specified by BC have been exchanged. In other conditions, when set, this bit indicates that all the data in TXFIFO has been loaded in the Shift register, and the Shift register has shifted out all the bits. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer completed</p> |
| 11             | R/W1C      | 0x0         | <p>TF_UDF<br/>TXFIFO Underrun<br/>This bit is set when the TXFIFO is underrun. Writing 1 to this bit clears it.<br/>0: TXFIFO is not underrun<br/>1: TXFIFO is underrun</p>                                                                                                                                                                                             |
| 10             | R/W1C      | 0x0         | <p>TF_OVF<br/>TXFIFO Overflow<br/>This bit is set when the TXFIFO is overflowed. Writing 1 to this bit clears it.<br/>0: TXFIFO is not overflowed<br/>1: TXFIFO is overflowed</p>                                                                                                                                                                                       |
| 9              | R/W1C      | 0x0         | <p>RX_UDF<br/>RXFIFO Underrun<br/>When set, this bit indicates that RXFIFO is underrun. Writing 1 to this bit clears it.<br/>0: RXFIFO is not underrun<br/>1: RXFIFO is underrun</p>                                                                                                                                                                                    |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                              |
| 8              | R/W1C      | 0x0         | <p>RX_OVF<br/>RXFIFO Overflow<br/>When set, this bit indicates that RXFIFO is overflowed. Writing 1 to this bit clears it.<br/>0: RXFIFO is not overflowed<br/>1: RXFIFO is overflowed</p>                                                               |
| 7              | /          | /           | /                                                                                                                                                                                                                                                        |
| 6              | R/W1C      | 0x0         | <p>TX_FULL<br/>TXFIFO Full<br/>This bit is set when the TXFIFO is full. Writing 1 to this bit clears it.<br/>0: TXFIFO is not Full<br/>1: TXFIFO is Full</p>                                                                                             |
| 5              | R/W1C      | 0x1         | <p>TX_EMP<br/>TXFIFO Empty<br/>This bit is set when the TXFIFO is empty. Writing 1 to this bit clears it.<br/>0: TXFIFO contains one or more words.<br/>1: TXFIFO is empty</p>                                                                           |
| 4              | R/W1C      | 0x1         | <p>TX_READY<br/>TXFIFO Ready<br/>0: TX_WL &gt; TX_TRIG_LEVEL<br/>1: TX_WL &lt;= TX_TRIG_LEVEL<br/>This bit will be immediately set to 1 if TX_WL &lt;= TX_TRIG_LEVEL.<br/>Writing "1" to this bit clears it. The TX_WL is the water level of TXFIFO.</p> |
| 3              | /          | /           | /                                                                                                                                                                                                                                                        |
| 2              | R/W1C      | 0x0         | <p>RX_FULL<br/>RXFIFO Full<br/>This bit is set when the RXFIFO is full. Writing 1 to this bit clears it.<br/>0: Not Full<br/>1: Full</p>                                                                                                                 |
| 1              | R/W1C      | 0x1         | <p>RX_EMP<br/>RXFIFO Empty<br/>This bit is set when the RXFIFO is empty. Writing 1 to this bit clears it.<br/>0: Not empty<br/>1: empty</p>                                                                                                              |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 0              | R/W1C      | 0x0         | <p>RX_RDY<br/>RXFIFO Ready<br/>0: RX_WL &lt; RX_TRIG_LEVEL<br/>1: RX_WL &gt;= RX_TRIG_LEVEL<br/>This bit will be immediately set to 1 if RX_WL &gt;= RX_TRIG_LEVEL.<br/>Writing "1" to this bit clears it. The RX_WL is the water level of RXFIFO.</p> |

#### 9.4.6.5 0x0018 SPI FIFO Control Register (Default Value: 0x0040\_0001)

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                    |
| 31             | R/WAC      | 0x0         | <p>TX_FIFO_RST<br/>TX FIFO Reset<br/>Writing '1' to this bit will reset the control portion of the TXFIFO and auto clear to '0' when completing the reset operation, writing '0' to this bit has no effect.</p>                                                                                                                                                |
| 30             | R/W        | 0x0         | <p>TF_TEST_ENB<br/>TX Test Mode Enable<br/>0: Disable<br/>1: Enable<br/>In normal mode, the TXFIFO can only be read by the SPI controller, writing '1' to this bit will switch the read and write function of TXFIFO to AHB bus. This bit is used to test the TXFIFO, do not set in normal operation, and do not set RF_TEST and TF_TEST at the same time.</p> |
| 29:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                              |
| 24             | R/W        | 0x0         | <p>TF_DRQ_EN<br/>TX FIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                   |
| 23:16          | R/W        | 0x40        | <p>TX_TRIG_LEVEL<br/>TX FIFO Empty Request Trigger Level</p>                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                   |
| 15             | R/WAC      | 0x0         | <p>RF_RST<br/>RXFIFO Reset<br/>Writing '1' to this bit will reset the control portion of the receiver FIFO, and auto clear to '0' when completing the reset operation, writing '0' to this bit has no effect.</p>                                                                                                                                             |
| 14             | R/W        | 0x0         | <p>RF_TEST<br/>RX Test Mode Enable<br/>0: Disable<br/>1: Enable<br/>In normal mode, the RXFIFO can only be written by the SPI controller, writing '1' to this bit will switch the read and write function of RXFIFO to AHB bus. This bit is used to test the RXFIFO, do not set in normal operation, and do not set RF_TEST and TF_TEST at the same time.</p> |
| 13:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                             |
| 8              | R/W        | 0x0         | <p>RF_DRQ_EN<br/>RXFIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                   |
| 7:0            | R/W        | 0x1         | <p>RX_TRIG_LEVEL<br/>RXFIFO Ready Request Trigger Level</p>                                                                                                                                                                                                                                                                                                   |

#### 9.4.6.6 0x001C SPI FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                      |
| 31             | R          | 0x0         | <p>TB_WR<br/>TXFIFO Write Buffer Write Enable</p>                                                                |
| 30:28          | R          | 0x0         | <p>TB_CNT<br/>TXFIFO Write Buffer Counter<br/>These bits indicate the number of words in TXFIFO Write Buffer</p> |
| 27:24          | /          | /           | /                                                                                                                |

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 23:16          | R          | 0x0         | <p>TF_CNT<br/>TXFIFO Counter<br/>These bits indicate the number of words in TXFIFO<br/>0: 0 byte in TXFIFO<br/>1: 1 byte in TXFIFO<br/>...<br/>64: 64 bytes in TXFIFO<br/>other: Reserved</p> |
| 15             | R          | 0x0         | <p>RB_WR<br/>RXFIFO Read Buffer Write Enable</p>                                                                                                                                              |
| 14:12          | R          | 0x0         | <p>RB_CNT<br/>RXFIFO Read Buffer Counter<br/>These bits indicate the number of words in RXFIFO Read Buffer</p>                                                                                |
| 11:8           | /          | /           | /                                                                                                                                                                                             |
| 7:0            | R          | 0x0         | <p>RF_CNT<br/>RXFIFO Counter<br/>These bits indicate the number of words in RXFIFO<br/>0: 0 byte in RXFIFO<br/>1: 1 byte in RXFIFO<br/>...<br/>64: 64 bytes in RXFIFO<br/>other: Reserved</p> |

#### 9.4.6.7 0x0020 SPI Wait Clock Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_WCR |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:20          | /          | /           | /                      |

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                             |
| 19:16          | R/W        | 0x0         | <p>SWC<br/>Dual mode direction switch wait clock counter (for master mode only).</p> <p>These bits control the number of wait states to be inserted before starting dual data transfer in dual SPI mode. The SPI module counts SPI_SCLK by SWC for delaying the next word data transfer.</p> <p>0: No wait states inserted<br/>n: n SPI_SCLK wait states inserted<br/>Cannot be written when XCH=1.</p> |
| 15:0           | R/W        | 0x0         | <p>WCC<br/>Wait Clock Counter (In master mode)</p> <p>These bits control the number of wait states to be inserted in data transfers. The SPI module counts SPI_SCLK by WCC for delaying the next word data transfer.</p> <p>0: No wait states inserted<br/>n: n SPI_SCLK wait states inserted<br/>Cannot be written when XCH=1.</p>                                                                     |

#### 9.4.6.8 0x0028 SPI Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                                                                                                            |
| 15             | R/W        | 0x0         | <p>SAMP_DL_CAL_START<br/>Sample Delay Calibration Start</p> <p>When set, it indicates that start sample delay chain calibration.<br/>Cannot be written when XCH=1.</p>                                                       |
| 14             | R          | 0x0         | <p>SAMP_DL_CAL_DONE<br/>Sample Delay Calibration Done</p> <p>When set, it indicates that the sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.<br/>Cannot be written when XCH=1.</p> |

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                               |
| 13:8           | R          | 0x20        | <p>SAMP_DL<br/>Sample Delay<br/>It indicates the number of delay cells corresponding to the current card clock. The delay time generated by these delay cells is equal to the cycle of the card clock nearly.<br/>Generally, it is necessary to do drive delay calibration when the card clock is changed.<br/>This bit is valid only when SAMP_DL_CAL_DONE is set.<br/>Cannot be written when XCH=1.</p> |
| 7              | R/W        | 0x0         | <p>SAMP_DL_SW_EN<br/>Sample Delay Software Enable<br/>When set, it indicates that enable sample delay specified at SAMP_DL_SW.<br/>Cannot be written when XCH=1.</p>                                                                                                                                                                                                                                      |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5:0            | R/W        | 0x0         | <p>SAMP_DL_SW<br/>Sample Delay Software<br/>The relative delay between the clock line and command line, data lines.<br/>It can be determined according to the value of SAMP_DL, the cycle of the card clock, and the input timing requirement of the device.<br/>Cannot be written when XCH=1.</p>                                                                                                        |

#### 9.4.6.9 0x0030 SPI Master Burst Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SPI_MBC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:24          | /          | /           | /                      |

| Offset: 0x0030 |            |             | Register Name: SPI_MBC                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                     |
| 23:0           | R/W        | 0x0         | <p>MBC<br/>Master Burst Counter<br/>In master mode, this field specifies the total burst number which includes the TXD, RXD, and dummy burst.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |

#### 9.4.6.10 0x0034 SPI Master Transmit Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SPI_MTC                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23:0           | R/W        | 0x0         | <p>MWTC<br/>Master Write Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy bursts. For saving bus bandwidth, the dummy bursts (all zero bits or all one bits) are sent by SPI Controller automatically.</p> <p>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p>Cannot be written when XCH=1.</p> |

#### 9.4.6.11 0x0038 SPI Master Burst Control Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SPI_BCC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:30          | /          | /           | /                      |

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 29             | R/W        | 0x0         | <p>Quad_EN<br/>Quad_Mode_EN<br/>The Quad mode includes Quad-Input and Quad-Output.<br/>0: Quad mode disable<br/>1: Quad mode enable<br/>Cannot be written when XCH=1.</p>                                                                                                                                                               |
| 28             | R/W        | 0x0         | <p>DRM<br/>Master Dual Mode_RX Enable<br/>It is only valid when Quad_Mode_EN=0.<br/>0: RX uses the single-bit mode<br/>1: RX uses the dual mode<br/>Cannot be written when XCH=1.</p>                                                                                                                                                   |
| 27:24          | R/W        | 0x0         | <p>DBC<br/>Master Dummy Burst Counter<br/>In master mode, this field specifies the burst number that should be sent before receiving in dual SPI mode. The data does not care by the device.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Cannot be written when XCH=1</p>                                                 |
| 23:0           | R/W        | 0x0         | <p>STC<br/>Master Single Mode Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent in the single mode before automatically sending dummy bursts. This is the first transmit counter in all bursts.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Cannot be written when XCH=1</p> |

#### 9.4.6.12 0x0040 SPI Bit-Aligned Transfer Configure Register (Default Value: 0x0000\_00A0)

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31             | R/WAC      | 0x0         | <p>TCE<br/>Transfer Control Enable<br/>In master mode, it is used to start to transfer the serial bits frame, it is only valid when Work Mode Select==0x10/0x11.<br/>0: Idle<br/>1: Initiates transfer<br/>Writing “1” to this bit will start to transfer serial bits frame (the value comes from the SPI TX Bit Register or SPI RX Bit Register), and will auto-clear after the bursts transfer completely. Writing ‘0’ to this bit has no effect.</p> |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0: Delay Sample Mode<br/>1: Standard Sample Mode<br/>In Standard Sample Mode, the SPI master samples the data at the standard rising edge of SCLK for each SPI mode;<br/>In Delay Sample Mode, the SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p>                                                                        |
| 29:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in SPI TX Bit Register (or SPI RX Bit Register) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/>It is only valid when Work Mode Select==0x10/0x11.</p>                                                                                                                       |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/>It is only valid when Work Mode Select==0x10/0x11.</p>                                                                                                                                                                                                                                                                                                      |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21:16          | R/W        | 0x00        | <p>RX_FEM_LEN</p> <p>Configure the length of serial data frame (burst) of RX</p> <p>000000: 0 bit</p> <p>000001: 1 bit</p> <p>...</p> <p>100000: 32 bits</p> <p>Other values: reserved</p> <p>It is only valid when Work Mode Select==0x10/0x11, and cannot be written when TCE (SPI_BATC[31])=1.</p>                                                                                                                              |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13:8           | R/W        | 0x00        | <p>TX_FEM_LEN</p> <p>Configure the length of serial data frame (burst) of TX</p> <p>000000: 0 bit</p> <p>000001: 1 bit</p> <p>...</p> <p>100000: 32 bits</p> <p>Other values: reserved</p> <p>It is only valid when Work Mode Select==0x10/0x11, and cannot be written when TCE=1.</p>                                                                                                                                             |
| 7              | R/W        | 0x1         | <p>SS_LEVEL</p> <p>When control SS signal manually, set this bit to '1' or '0' to control the level of SS signal.</p> <p>0: Set SS to low</p> <p>1: Set SS to high</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE=1.</p>                                                                                                                                             |
| 6              | R/W        | 0x0         | <p>SS_OWNER</p> <p>SS Output Owner Select</p> <p>Usually, the controller sends the SS signal automatically with data together. When this bit is set to 1, the software must manually write SS_LEVEL (SPI_BATC[7]) to 1 or 0 to control the level of the SS signal.</p> <p>0: SPI controller</p> <p>1: Software</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE=1.</p> |

| Offset: 0x0040 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 5              | R/W        | 0x1         | <p>SPOL</p> <p>SPI Chip Select Signal Polarity Control</p> <p>0: Active high polarity (0 = Idle)</p> <p>1: Active low polarity (1 = Idle)</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE=1.</p>                                                                                                    |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 3:2            | R/W        | 0x0         | <p>SS_SEL</p> <p>SPI Chip Select</p> <p>Select one of four external SPI Master/Slave Devices</p> <p>00: SPI_SS0 will be asserted</p> <p>01: SPI_SS1 will be asserted</p> <p>10: SPI_SS2 will be asserted</p> <p>11: SPI_SS3 will be asserted</p> <p>It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, cannot be written when TCE=1.</p> |
| 1:0            | R/W        | 0x0         | <p>WMS</p> <p>Work Mode Select</p> <p>00: Data frame is byte aligned in standard SPI, dual-output/dual input SPI, dual IO SPI, and quad-output/quad-input SPI</p> <p>01: Reserved</p> <p>10: Data frame is bit aligned in 3-wire SPI</p> <p>11: Data frame is bit aligned in standard SPI</p>                                                                    |

#### 9.4.6.13 0x0044 SPI Bit-Aligned Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SPI_BA_CCR                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                  |
| 7:0            | R/W        | 0x0         | <p>CDR_N</p> <p>Clock Divide Rate (Master Mode Only)</p> <p>The SPI_SCLK is determined according to the following equation:<br/> <math>SPI\_CLK = Source\_CLK / (2 * (CDR_N + 1))</math>.</p> <p>This register is only valid when Work Mode Select==0x10/0x11.</p> |

#### 9.4.6.14 0x0048 SPI TX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SPI_TBR                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | <p>VTB<br/>The Value of the Transmit Bits<br/>This register is used to store the value of the transmitted serial data frame.<br/>In the process of transmission, the LSB is transmitted first.<br/>This register is only valid when Work Mode Select==0x10/0x11.</p> |

#### 9.4.6.15 0x004C SPI RX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | <p>VRB<br/>The Value of the Receive Bits<br/>This register is used to store the value of the received serial data frame.<br/>In the process of transmission, the LSB is transmitted first.<br/>This register is only valid when Work Mode Select==0x10/0x11.</p> |

#### 9.4.6.16 0x0088 SPI Normal DMA Mode Control Register (Default Value: 0x0000\_00E5)

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                   |
| 7:6            | R/W        | 0x11        | <p>SPI_ACT_M<br/>SPI NDMA Active Mode<br/>00: dma_active is low<br/>01: dma_active is high<br/>10: dma_active is controlled by dma_request (DRQ)<br/>11: dma_active is controlled by controller</p> |
| 5              | R/W        | 0x1         | <p>SPI_ACK_M<br/>SPI NDMA Acknowledge Mode<br/>0: active fall do not care ack<br/>1: active fall must after detect ack is high</p>                                                                  |

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 4:0            | R/W        | 0x05        | SPI_DMA_WAIT<br>Delay Cycles<br>The counts of hold cycles from DMA last signal high to dma_active high |

#### 9.4.6.17 0x0100 DBI Control Register 0 (Default Value: 0x0010\_0000)

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31             | R/W        | 0x0         | CMDT<br>Command Type<br>0: Write Command<br>1: Read Command                                                                                                                             |
| 30:20          | R/W        | 0x1         | WCDC<br>Write Command Dummy Cycles<br>Controls dummy cycles between two write commands<br>Range 1~255<br>Default Condition: there is a dbi_clk cycle between each command or parameter. |
| 19             | R/W        | 0x0         | DAT_SEQ<br>Output Data Sequence<br>0: MSB First<br>1: LSB First                                                                                                                         |
| 18:16          | R/W        | 0x0         | RGB_SEQ<br>Output RGB Sequence<br>000: RGB<br>001: RBG<br>010: GRB<br>011: GBR<br>100: BRG<br>101: BGR<br>110, 111: Reserved                                                            |

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
| 15             | R/W        | 0x0         | TRAN_MOD<br>Transmit Mode<br>0: Command/Parameter<br>1: Video                                                                                                  |
| 14:12          | R/W        | 0x0         | DAT_FMT<br>Output Data Format<br>000: RGB111<br>001: RGB444<br>010: RGB565<br>011: RGB666<br>100: RGB888 (only for 2 Data Lane Interface)<br>101~111: Reserved |
| 11             | /          | /           | /                                                                                                                                                              |
| 10:8           | R/W        | 0x0         | DBI Interface<br>000: 3 Line Interface I<br>001: 3 Line Interface II<br>010: 4 Line Interface I<br>011: 4 Line Interface II<br>100: 2 Data Lane Interface      |

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:4            | R/W        | 0x0         | <p>RGB_Source_Format</p> <p>When video_source_type is RGB32 (DBI_CTL_0[bit0] = 0)</p> <p>0000: RGB</p> <p>0001: RBG</p> <p>0010: GRB</p> <p>0011: GBR</p> <p>0100: BRG</p> <p>0101: BGR</p> <p>Others: Reserved</p> <p>When video_source_type is RGB16 (DBI_CTL_0[bit0] = 1)</p> <p>0000: RGB</p> <p>0001~0100: Reserved</p> <p>0101: BGR</p> <p>0110: GRBG_0 {G[5:3]R[4:0]B[4:0]G[2:0]}</p> <p>0111: GBRG_0 {G[5:3]B[4:0]R[4:0]G[2:0]}</p> <p>1000: GRBG_1 {G[2:0]R[4:0]B[4:0]G[5:3]}</p> <p>1001: GBRG_1 {G[2:0]B[4:0]R[4:0]G[5:3]}</p> <p>Others: Reserved</p> |
| 3              | R/W        | 0x0         | <p>DUM_VAL</p> <p>Dummy Cycle Value</p> <p>Output Value During Dummy Cycle</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2              | R/W        | 0x0         | <p>RGB_BO</p> <p>RGB Bit Order</p> <p>0: Remain the sequence of RGB data</p> <p>1: Swap the higher bit and the lower bit for each component of DRAM RGB</p>                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1              | R/W        | 0x0         | <p>ELEMENT_A_POS</p> <p>Element A Position</p> <p>Only for RGB32 Data Format</p> <p>0: A component is in the bit[31:24] of data source</p> <p>1: A component is in the bit[7:0] of data source</p>                                                                                                                                                                                                                                                                                                                                                                |
| 0              | R/W        | 0x0         | <p>VI_SRC_TYPE</p> <p>Video Source Type</p> <p>0: RGB32</p> <p>1: RGB16</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

**9.4.6.18 0x0104 DBI Control Register 1 (Default Value: 0x0000\_0001)**

| Offset: 0x0104 |            |             | Register Name: DBI_CTL_1                                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                        |
| 31             | R/WAC      | 0x0         | DBI_SOFT_TRG<br>DBI soft trigger<br>It is only available for software trigger mode. Writing '1' to this bit will start DBI TX module and auto clear to '0' when completing start operation, writing '0' to this bit has no effect. |
| 30:29          | R/W        | 0x0         | DBI_EN_MODE_SEL<br>DBI Enable Mode Select<br>00: Always on DBI mode<br>01: Software trigger mode<br>10: Timer trigger mode<br>11: TE trigger mode                                                                                  |
| 28             | /          | /           | /                                                                                                                                                                                                                                  |
| 27:26          | R/W        | 0x0         | RGB666_FMT<br>2 Data Lane RGB666 Format<br>00: Normal Format<br>01: Special Format for ILITEK<br>10: Special Format for New Vision                                                                                                 |
| 25             | R/W        | 0x0         | DBI_RXCLK_INV<br>DBI rx clock inverse<br>0: Sample data by using the positive edge of the output clock<br>1: Sample data by using the negative edge of the output clock                                                            |
| 24             | R/W        | 0x0         | DBI_CLKO_MOD<br>DBI output clock mode<br>0: DBI clock always on (DCX Setup/hold equals one clock cycle)<br>1: DBI clock auto gating (DCX Setup/hold equals to a half clock cycle)                                                  |

| Offset: 0x0104 |            |             | Register Name: DBI_CTL_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23             | R/W        | 0x0         | <p>DBI_CLKO_INV<br/>DBI clock output inverse</p> <p><b>When the bit24 (DBI output clock mode) is 0.</b></p> <p>0: The falling edge releases the CSX signal, and the falling edge releases data</p> <p>1: The rising edge releases the CSX signal, and the rising edge releases data</p> <p><b>When the bit24 (DBI output clock mode) is 1.</b></p> <p>0: The rising edge releases the CSX signal, and the falling edge releases data</p> <p>1: The falling edge releases the CSX signal, and the rising edge releases data</p> |
| 22             | R/W        | 0x0         | <p>DCX_DATA<br/>DCX Data Value</p> <p>0: DCX Value equal to 0</p> <p>1: DCX Value equal to 1</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 21             | R/W        | 0x0         | <p>RGB 16 Data Source Select<br/>RGB 16 Data Source Select</p> <p>0: Pixel1 is stored in the higher bit of address, and Pixel0 is stored in the lower bit of address</p> <p>1: Pixel0 is stored in the higher bit of address, and Pixel1 is stored in the lower bit of address</p>                                                                                                                                                                                                                                             |
| 20             | R/W        | 0x0         | <p>RDAT_LSB<br/>Bit Order of Read Data</p> <p>0: A reading data is the higher bit</p> <p>1: A reading data is the lower bit</p>                                                                                                                                                                                                                                                                                                                                                                                                |
| 19:16          | /          | /           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:8           | R/W        | 0x0         | <p>RCDC<br/>Read Command Dummy Cycles</p> <p>The dummy cycle between the read command and read data</p> <p>Reading 1-byte (8 bits) data has not dummy cycle.</p>                                                                                                                                                                                                                                                                                                                                                               |
| 7:0            | R/W        | 0x1         | <p>RDBN<br/>Read Data Number of Bytes</p> <p>Sample Bytes data based on configuration.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 9.4.6.19 0x0108 DBI Control Register 2 (Default Value: 0x0000\_4000)

| Offset: 0x0108 |            |             | Register Name: DBI_CTL_2                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:26          | /          | /           | /                                                                                                                                                                                                         |
| 15             | R/W        | 0x0         | DBI_FIFO_DRQ_EN<br>DBI FIFO DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                                                 |
| 14:8           | R/W        | 0x40        | DBI_TRIG_LEVEL<br>DBI FIFO Empty Request Trigger Level                                                                                                                                                    |
| 7              | /          | /           | /                                                                                                                                                                                                         |
| 6              | R/W        | 0x0         | DBI_SDI_OUT_SEL<br>DBI SDI PIN Output Select<br>The signal is used with the DBI SDI PIN Function Sel bit.<br>0: Output WRX (When DBI DCX PIN Function Sel = 0, the SDI pin outputs data)<br>1: Output DCX |
| 5              | R/W        | 0x0         | DBI_DCX_SEL<br>DBI DCX PIN Function Select<br>0: DBI DCX Function<br>1: WRX (2 Data Lane Interface)                                                                                                       |
| 4:3            | R/W        | 0x0         | DBI_SDI_SEL<br>DBI SDI PIN Function Select<br>00: DBI_SDI (Interface II)<br>01: DBI_TE<br>10: DBI_DCX<br>11: Reserved                                                                                     |
| 2              | R/W        | 0x0         | TE_DBC_SEL<br>TE debounce function select<br>0: debounce<br>1: no-debounce                                                                                                                                |
| 1              | R/W        | 0x0         | TE_TRIG_SEL<br>TE edge trigger select<br>0: TE rising edge<br>1: TE falling edge                                                                                                                          |
| 0              | R/W        | 0x0         | TE_EN<br>TE enable<br>0: TE Disable<br>1: TE Enable                                                                                                                                                       |

#### 9.4.6.20 0x010C DBI Timer Control Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: DBI_Timer                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31             | R/W        | 0x0         | <p>DBI_TM_EN<br/>DBI Timer Enable<br/>0: Enable<br/>1: Disable</p>                                                                                                                                                                                                                                                                                                                                                                                                    |
| 30:0           | R/W        | 0x0         | <p>DBI Timer Value<br/>It sets the time interval between sending data twice, which is frame blanking.<br/>It is used to set the time at which the interrupt of the DBI Timer is triggered. When the Timer_EN is 1, the timer starts to count (the clock of the counting is SCLK), and the counter reaches the target value to trigger the Timer_INT of DBI, the data will start to send in series.</p> <p><b>Note: Do not count when sending the series data.</b></p> |

#### 9.4.6.21 0x0110 DBI Video Size Register (Default Value: 0x01E0\_0140)

| Offset: 0x0110 |            |             | Register Name: DBI_Video_Size                   |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:27          | /          | /           | /                                               |
| 26:16          | R/W        | 0x1E0       | V_SIZE<br>It is used to generate the Frame int. |
| 15:11          | /          | /           | /                                               |
| 10:0           | R/W        | 0x140       | H_SIZE<br>It is used to generate the Line int.  |

#### 9.4.6.22 0x0120 DBI Interrupt Register (Default Value: 0x0000\_4000)

| Offset: 0x0120 |            |             | Register Name: DBI_INT |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:15          | /          | /           | /                      |

| Offset: 0x0120 |            |             | Register Name: DBI_INT                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                          |
| 14             | R/W1C      | 0x1         | <p>DBI_FIFO_EMPTY_INT<br/>DBI FIFO Empty Interrupt Status<br/>0: DBI_FIFO is not empty<br/>1: DBI_FIFO is empty</p>                                                                                                                                  |
| 13             | R/W1C      | 0x0         | <p>DBI_FIFO_FULL_INT<br/>DBI FIFO Full Interrupt Status<br/>0: DBI_FIFO is not full<br/>1: DBI_FIFO is full</p>                                                                                                                                      |
| 12             | R/W1C      | 0x0         | <p>TIMER_INT<br/>It indicates that the timer has been count sclk cycles to the value of DBI_Timer Register[30:0]. Writing 1 to this bit clears it.<br/>0: Timer has not been achieved the objective<br/>1: Timer has been achieved the objective</p> |
| 11             | R/W1C      | 0x0         | <p>RD_DONE_INT<br/>It indicates that the number of byte setting in DBI_Control Register 1[19:8] has been read. Writing 1 to this bit clears it.<br/>0: All data has not been read<br/>1: All data has been read</p>                                  |
| 10             | R/W1C      | 0x0         | <p>TE_INT<br/>It indicates that the TE signal has been changed. Writing 1 to this bit clears it.<br/>0: TE signal has not been changed<br/>1: TE signal has been changed</p>                                                                         |
| 9              | R/W1C      | 0x0         | <p>FRAM_DONE_INT<br/>It indicates that a frame video data has been sent. Writing 1 to this bit clears it.<br/>0: A frame video has not been sent<br/>1: A frame video has been sent</p>                                                              |
| 8              | R/W1C      | 0x0         | <p>LINE_DONE_INT<br/>It indicates that a line of video data has been sent. Writing 1 to this bit clears it.<br/>0: A line of video data has not been sent<br/>1: A line of video data has been sent</p>                                              |
| 7              | /          | /           | /                                                                                                                                                                                                                                                    |

| Offset: 0x0120 |            |             | Register Name: DBI_INT                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 6              | R/W        | 0x0         | <p>DBI_FIFO_EMPTY_INT_EN<br/>DBI FIFO Empty Interrupt Enable<br/>0: Disable<br/>1: Enable</p> |
| 5              | R/W        | 0x0         | <p>DBI_FIFO_FULL_INT_EN<br/>DBI FIFO Full Interrupt Enable<br/>0: Disable<br/>1: Enable</p>   |
| 4              | R/W        | 0x0         | <p>TIMER_INT_EN<br/>Timer Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                   |
| 3              | R/W        | 0x0         | <p>RD_DONE_INT_EN<br/>Read Done Interrupt Enable<br/>0: Disable<br/>1: Enable</p>             |
| 2              | R/W        | 0x0         | <p>TE_INT_EN<br/>TE Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                         |
| 1              | R/W        | 0x0         | <p>FRAM_DONE_INT_EN<br/>Frame Done Interrupt Enable<br/>0: Disable<br/>1: Enable</p>          |
| 0              | R/W        | 0x0         | <p>LINE_DONE_INT_EN<br/>Line Done Interrupt Enable<br/>0: Disable<br/>1: Enable</p>           |

#### 9.4.6.23 0x0124 DBI Debug Register 0 (Default Value: 0x007F\_0000)

| Offset: 0x0124 |            |             | Register Name: DBI_Debug_0 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:23          | /          | /           | /                          |

| Offset: 0x0124 |            |             | Register Name: DBI_Debug_0                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 22:16          | R          | 0x7F        | DBI_FIFO_AVAIL<br>DBI_FIFO ROOM VALID<br>0~127 Words                             |
| 15:13          | /          | /           | /                                                                                |
| 12             | R          | 0x0         | TE_VAL<br>TE input value<br>0: TE not Trigger<br>1: TE Trigger                   |
| 11:8           | R          | 0x0         | DBI_RXCS<br>FSM for DBI Receive<br>RX_BS0 ~ RX_BS6 , Gray - Code                 |
| 7:4            | R          | 0x0         | SH_CS<br>FSM for shifter<br>0~11 : SH0~SH11                                      |
| 3:2            | /          | /           | DBI_TXCS<br>FSM for DBI Transmit<br>00: IDLE<br>01: SHIF<br>10: DUMY<br>11: READ |
| 1:0            | R          | 0x0         | MEM_CS<br>FSM for DBI Memory<br>00: IDLE_FRM<br>01: FRM_POS<br>10: FRM_RDY       |

#### 9.4.6.24 0x0128 DBI Debug Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: DBI_Debug_1                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:26          | /          | /           | /                                                                         |
| 25:16          | R          | 0x0         | LCNT<br>Line counter<br>The number of pixel lines that are currently sent |
| 15:12          | /          | /           | /                                                                         |

| Offset: 0x0128 |            |             | Register Name: DBI_Debug_1                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 11:0           | R          | 0x0         | <p>CCNT<br/>Component counter<br/>The number of RGB components that are currently sent<br/>The field is equal to pixel_cnt *3.</p> |

#### 9.4.6.25 0x0200 SPI TX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:0           | R/W        | 0x0         | <p>TDATA<br/>Transmit Data<br/>This register can be accessed in the byte, half-word, or word unit by AHB. In the byte accessing method, if there are rooms in TXFIFO, one burst data is written to TXFIFO and the depth is increased by 1. In the half-word accessing method, two SPI burst data are written and the TXFIFO depth is increased by 2. In the word accessing method, four SPI burst data are written and the TXFIFO depth is increased by 4.<br/><b>Note: This address is writable-only if TF_TEST is '0', and if TF_TEST is set to '1', this address is readable and writable to test the TX FIFO through the AHB bus.</b></p> |

## 9.4.6.26 0x0300 SPI RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: SPI_RXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:0           | R          | 0x0         | <p>RDATa<br/>Receive Data</p> <p>This register can be accessed in the byte, half-word, or word unit by AHB. In the byte accessing method, if there are data in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In the half-word accessing method, two SPI bursts are returned and the RXFIFO depth is decreased by 2. In the word accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.</p> <p><b>Note:</b> This address is readable-only if RF_TEST is '0', and if RF_TEST is set to '1', this address is readable and writable to test the RX FIFO through the AHB bus.</p> |

## 9.5 USB2.0 DRD

### 9.5.1 Overview

The USB2.0 dual-role device (USB2.0 DRD) supports both device and host functions which can also be configured as a Host-only or Device-only controller. It complies with the USB2.0 Specification.

For saving CPU bandwidth, the DMA interface of the DRD module can also support the external DMA controller to do the data transfer between the memory and the DRD FIFO. The DRD core also supports USB power saving functions.

The USB2.0 DRD has the following features:

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

- Device and host controller share a 8K SRAM and a physical PHY

### 9.5.2 Block Diagram

The following figure shows the block diagram of USB2.0 DRD Controller.

Figure 9-63 USB2.0 DRD Controller Block Diagram



### 9.5.3 Functional Description

#### 9.5.3.1 External Signals

Table 9-18 USB2.0 DRD External Signals

| Signal  | Description                             | Type |
|---------|-----------------------------------------|------|
| USBO-DP | USB2.0 DRD differential signal positive | AI/O |
| USBO-DM | USB2.0 DRD differential signal negative | AI/O |

### 9.5.3.2 Controller and PHY Connection Diagram

Figure 9-64 USB2.0 DRD Controller and PHY Connection Diagram



## 9.6 USB2.0 HOST

### 9.6.1 Overview

The USB Host Controller is fully compliant with USB 2.0 Specification, Enhanced Host Controller Interface (EHCI) Specification Revision 1.0 and Open Host Controller Interface (OHCI) Specification Release 1.0a.

The USB2.0 host controller includes the following features:

- Complies with USB2.0 Specification
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
  - Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) Device
  - Supports only 1 USB Root port shared between EHCI and OHCI
- An internal DMA Controller for data transfer with memory

### 9.6.2 Block Diagram

The following figure shows the block diagram of USB2.0 Host Controller.

Figure 9-65 USB2.0 Host Controller Block Diagram



### 9.6.3 Functional Description

#### 9.6.3.1 External Signals

Table 9-19 USB2.0 Host External Signals

| Signal  | Description                              | Type |
|---------|------------------------------------------|------|
| USB1-DP | USB2.0 Host differential signal positive | AI/O |
| USB1-DM | USB2.0 Host differential signal negative | AI/O |

#### 9.6.3.2 Controller and PHY Connection Diagram

Figure 9-66 USB2.0 Host Controller and PHY Connection Diagram



### 9.6.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| USB1        | 0x04200000   |

| Register Name                   | Offset | Description                                     |
|---------------------------------|--------|-------------------------------------------------|
| <b>EHCI Capability Register</b> |        |                                                 |
| E_CAPLENGTH                     | 0x0000 | EHCI Capability Register Length Register        |
| E_HCIVERSION                    | 0x0002 | EHCI Host Interface Version Number Register     |
| E_HCSPARAMS                     | 0x0004 | EHCI Host Control Structural Parameter Register |
| E_HCCPARAMS                     | 0x0008 | EHCI Host Control Capability Parameter Register |

| Register Name                                     | Offset | Description                                  |
|---------------------------------------------------|--------|----------------------------------------------|
| E_HCSPPORTROUTE                                   | 0x000C | EHCI Companion Port Route Description        |
| <b>EHCI Operational Register</b>                  |        |                                              |
| E_USBCMD                                          | 0x0010 | EHCI USB Command Register                    |
| E_USBSTS                                          | 0x0014 | EHCI USB Status Register                     |
| E_USBINTR                                         | 0x0018 | EHCI USB Interrupt Enable Register           |
| E_FRINDEX                                         | 0x001C | EHCI USB Frame Index Register                |
| E_CTRLDSSEGMENT                                   | 0x0020 | EHCI 4G Segment Selector Register            |
| E_PERIODICLISTBASE                                | 0x0024 | EHCI Frame List Base Address Register        |
| E_ASYNCLISTADDR                                   | 0x0028 | EHCI Next Asynchronous List Address Register |
| E_CONFIGFLAG                                      | 0x0050 | EHCI Configured Flag Register                |
| E_PORTSC                                          | 0x0054 | EHCI Port Status/Control Register            |
| <b>OHCI Control and Status Partition Register</b> |        |                                              |
| O_HcControl                                       | 0x0404 | OHCI Control Register                        |
| O_HcCommandStatus                                 | 0x0408 | OHCI Command Status Register                 |
| O_HcInterruptStatus                               | 0x040C | OHCI Interrupt Status Register               |
| O_HcInterruptEnable                               | 0x0410 | OHCI Interrupt Enable Register               |
| O_HcInterruptDisable                              | 0x0414 | OHCI Interrupt Disable Register              |
| <b>OHCI Memory Pointer Partition Register</b>     |        |                                              |
| O_HcHCCA                                          | 0x0418 | OHCI HCCA Base                               |
| O_HcPeriodCurrentED                               | 0x041C | OHCI Period Current ED Base                  |
| O_HcControlHeadED                                 | 0x0420 | OHCI Control Head ED Base                    |
| O_HcControlCurrentED                              | 0x0424 | OHCI Control Current ED Base                 |
| O_HcBulkHeadED                                    | 0x0428 | OHCI Bulk Head ED Base                       |
| O_HcBulkCurrentED                                 | 0x042C | OHCI Bulk Current ED Base                    |
| O_HcDoneHead                                      | 0x0430 | OHCI Done Head Base                          |
| <b>OHCI Frame Counter Partition Register</b>      |        |                                              |
| O_HcFmInterval                                    | 0x0434 | OHCI Frame Interval Register                 |
| O_HcFmRemaining                                   | 0x0438 | OHCI Frame Remaining Register                |
| O_HcFmNumber                                      | 0x043C | OHCI Frame Number Register                   |
| O_HcPeriodicStart                                 | 0x0440 | OHCI Periodic Start Register                 |
| O_HcLSThreshold                                   | 0x0444 | OHCI LS Threshold Register                   |
| <b>OHCI Root Hub Partition Register</b>           |        |                                              |
| O_HcRhDescriptorA                                 | 0x0448 | OHCI Root Hub Descriptor Register A          |
| O_HcRhDescriptorB                                 | 0x044C | OHCI Root Hub Descriptor Register B          |

| Register Name                                    | Offset | Description                           |
|--------------------------------------------------|--------|---------------------------------------|
| O_HcRhStatus                                     | 0x0450 | OHCI Root Hub Status Register         |
| O_HcRhPortStatus                                 | 0x0454 | OHCI Root Hub Port Status Register    |
| <b>HCI Controller and PHY Interface Register</b> |        |                                       |
| HCI_Interface                                    | 0x0800 | HCI Interface Register                |
| HCI_CTRL3                                        | 0x0808 | HCI Control Register                  |
| PHY_Control                                      | 0x0810 | PHY Control Register                  |
| PHY_STATUS                                       | 0x0824 | PHY Status Register                   |
| HCI SIE Port Disable Control                     | 0x0828 | HCI SIE Port Disable Control Register |

## 9.6.5 EHCI Register Description

### 9.6.5.1 0x0000 EHCI Identification Register (Default Value:0x10)

| Offset:0x0000 |            |             | Register Name: CAPLENGTH                                                                                                                  |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                               |
| 7:0           | R          | 0x10        | CAPLENGTH<br>The value in these bits indicates an offset to add to register base to find the beginning of the Operational Register Space. |

### 9.6.5.2 0x0002 EHCI Host Interface Version Number Register (Default Value:0x0100)

| Offset: 0x0002 |            |             | Register Name: HCIVERSION                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                   |
| 15:0           | R          | 0x0100      | HCIVERSION<br>This is a 16-bit register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |

### 9.6.5.3 0x0004 EHCI Host Control Structural Parameter Register (Default Value:0x0000\_1101)

| Offset: 0x0004 |            |             | Register Name: HCSPARAMS |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:24          | /          | /           | /                        |
| 23:20          | R          | 0x0         | Debug Port Number        |

| Offset: 0x0004 |                                                                                                                                                                                         |             | Register Name: HCSPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|                |                                                                                                                                                                                         |             | <p>This register identifies which of the host controller ports is the debug port. The value is the port number (one based) of the debug port.</p> <p>This field will always be '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 19:16          | /                                                                                                                                                                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 15:12          | R                                                                                                                                                                                       | 0x1         | <p>Number of Companion Controller (N_CC)</p> <p>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).</p> <p>This field will always be '0'.</p>                                                                                                                                                                                                                                                                                                                                       |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 11:8           | R                                                                                                                                                                                       | 0x1         | <p>Number of Port per Companion Controller (N_PCC)</p> <p>This field indicates the number of ports supported per companion host controller host controller. It is used to indicate the port routing configuration to system software.</p> <p>This field will always fix with '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 7              | R                                                                                                                                                                                       | 0x0         | <p>Port Routing Rules</p> <p>This field indicates the method used by this implementation for how all ports are mapped to companion controllers. The value of this field has the following interpretation:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on.</td></tr> <tr> <td>1</td><td>The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array.</td></tr> </tbody> </table> <p>This field will always be '0'.</p> | Value | Meaning | 0 | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. | 1 | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array. |
| Value          | Meaning                                                                                                                                                                                 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 0              | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 1              | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTROUTE array.                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 6:4            | /                                                                                                                                                                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 3:0            | R                                                                                                                                                                                       | 0x1         | <p>N_PORTS</p> <p>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.</p> <p>This field is always 1.</p>                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |

## 9.6.5.4 0x0008 EHCI Host Control Capability Parameter Register (Default Value:0x0000\_A026)

| Offset: 0x0008 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:8           | R          | 0xA0        | <p>EHCI Extended Capabilities Pointer (EECP)</p> <p>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.</p> <p>The value of this field is always '00b'.</p>                                                                   |
| 7:4            | R          | 0x2         | <p>Isochronous Scheduling Threshold</p> <p>This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.</p> <p>When bit[7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures(one or more) before flushing the state. When bit[7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.</p>                     |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2              | R          | 0x1         | <p>Asynchronous Schedule Park Capability</p> <p>If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.</p>                                                                                                                                                                                  |
| 1              | R          | 0x1         | <p>Programmable Frame List Flag</p> <p>If this bit is set to a zero, then system software must use a frame list length of 1024 elements with this host controller. The USBCMD register Frame List Size field is a read-only register and should be set to zero.</p> <p>If set to 1, then system software can specify and use the frame list in the USBCMD register Frame List Size field to configure the host controller.</p> <p>The frame list must always aligned on a 4K page boundary. This requirement ensures that the frame list is always physically contiguous.</p> |
| 0              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

### 9.6.5.5 0x000C EHCI Companion Port Route Description (Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: HCSP-PORTROUTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:0           | R          | 0x0         | <p>HCSP-PORTROUTE</p> <p>This optional field is valid only if Port Routing Rules field in HCSPARAMS register is set to a one.</p> <p>This field is used to allow a host controller implementation to explicitly describe to which companion host controller each implemented port is mapped. This field is a 15-element nibble array (each 4 bit is one array element). Each array location corresponds one-to-one with a physical port provided by the host controller (e.g. PORTROUTE [0] corresponds to the first PORTSC port, PORTROUTE [1] to the second PORTSC port, etc.). The value of each element indicates to which the companion host controllers this port is routed. Only the first N_PORTS elements have valid information. A value of zero indicates that the port is routed to the lowest numbered function companion host controller. A value of one indicates that the port is routed to the next lowest numbered function companion host controller, and so on.</p> |

### 9.6.5.6 0x0010 EHCI USB Command Register (Default Value:0x0008\_0B00)

| Offset: 0x0010 |                                         |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
|----------------|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------|------|----------|------|---------------|------|---------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| Bit            | Read/Write                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 31:24          | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 23:16          | R/W                                     | 0x08        | <p>Interrupt Threshold Control</p> <p>The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Minimum Interrupt Interval</th> </tr> </thead> <tbody> <tr> <td>0x00</td> <td>Reserved</td> </tr> <tr> <td>0x01</td> <td>1 micro-frame</td> </tr> <tr> <td>0x02</td> <td>2 micro-frame</td> </tr> <tr> <td>0x04</td> <td>4 micro-frame</td> </tr> <tr> <td>0x08</td> <td>8 micro-frame(default, equates to 1 ms)</td> </tr> <tr> <td>0x10</td> <td>16 micro-frame(2ms)</td> </tr> <tr> <td>0x20</td> <td>32 micro-frame(4ms)</td> </tr> <tr> <td>0x40</td> <td>64 micro-frame(8ms)</td> </tr> </tbody> </table> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame | 0x04 | 4 micro-frame | 0x08 | 8 micro-frame(default, equates to 1 ms) | 0x10 | 16 micro-frame(2ms) | 0x20 | 32 micro-frame(4ms) | 0x40 | 64 micro-frame(8ms) |
| Value          | Minimum Interrupt Interval              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x00           | Reserved                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x01           | 1 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x02           | 2 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x04           | 4 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x08           | 8 micro-frame(default, equates to 1 ms) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x10           | 16 micro-frame(2ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x20           | 32 micro-frame(4ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x40           | 64 micro-frame(8ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |

| Offset: 0x0010 |            |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>Any other value in this register yields undefined results.</p> <p>The default value in this field is 0x08 .</p> <p>Software modifications to this bit while HC Halted bit is equal to zero results in undefined behavior.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11             | R          | 0x1         | <p>Asynchronous Schedule Park Mode Enable (OPTIONAL)</p> <p>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.</p>                                                                                                                                                                                                                                                                                     |
| 10             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9:8            | R          | 0x3         | <p>Asynchronous Schedule Park Mode Count (OPTIONAL)</p> <p>Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this field defaults to 0x3 and is W/R. Otherwise it defaults to zero and is R. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the Asynchronous schedule before continuing traversal of the Asynchronous schedule.</p> <p>Valid value are 0x1 to 0x3. Software must not write a zero to this bit when Park Mode Enable is a one as it will result in undefined behavior.</p>                                                                      |
| 7              | R/W        | 0x0         | <p>Light Host Controller Reset (OPTIONAL)</p> <p>This control bit is not required.</p> <p>If implemented, it allows the driver to reset the EHCI controller without affecting the state of the ports or relationship to the companion host controllers. For example, the PORSTC registers should not be reset to their default values and the CF bit setting should not go to zero (retaining port ownership relationships).</p> <p>A host software read of this bit as zero indicates the Light Host Controller Reset has completed and it is safe for software to re-initialize the host controller. A host software read of this bit as a one indicates the Light Host</p> |
| 6              | R/W        | 0x0         | <p>Interrupt on Async Advance Doorbell</p> <p>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.</p> <p>When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS. if the Interrupt on Async Advance Enable bit in the</p>                                                                                                                                                                                                             |

| Offset: 0x0010 |                                                                    |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
|----------------|--------------------------------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|-----|-------------------------------------------|-----|--------------------------------------------------------------------|-----|-----------------------------------------------------------|-----|----------|
| Bit            | Read/Write                                                         | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
|                |                                                                    |             | <p>USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p>                                                                                                                                                                                                                                                                                                                                    |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 5              | R/W                                                                | 0x0         | <p>Asynchronous Schedule Enable</p> <p>This bit controls whether the host controller skips processing the Asynchronous Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Asynchronous Schedule.</td></tr> <tr> <td>1</td><td>Use the ASYNLISTADDR register to access the Asynchronous Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                         | Bit Value | Meaning | 0   | Do not process the Asynchronous Schedule. | 1   | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |     |                                                           |     |          |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 0              | Do not process the Asynchronous Schedule.                          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 1              | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 4              | R/W                                                                | 0x0         | <p>Periodic Schedule Enable</p> <p>This bit controls whether the host controller skips processing the Periodic Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                     | Bit Value | Meaning | 0   | Do not process the Periodic Schedule.     | 1   | Use the PERIODICLISTBASE register to access the Periodic Schedule. |     |                                                           |     |          |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 0              | Do not process the Periodic Schedule.                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 1              | Use the PERIODICLISTBASE register to access the Periodic Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 3:2            | R/W                                                                | 0x0         | <p>Frame List Size</p> <p>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This field specifies the size of the</p> <p>Frame list. The size the frame list controls which bits in the Frame Index</p> <p>Register should be used for the Frame List Current index. Values mean:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>00b</td><td>1024 elements(4096bytes)Default value</td></tr> <tr> <td>01b</td><td>512 elements(2048bytes)</td></tr> <tr> <td>10b</td><td>256 elements(1024bytes)For resource-constrained condition</td></tr> <tr> <td>11b</td><td>reserved</td></tr> </tbody> </table> <p>The default value is '00b'.</p> | Bits      | Meaning | 00b | 1024 elements(4096bytes)Default value     | 01b | 512 elements(2048bytes)                                            | 10b | 256 elements(1024bytes)For resource-constrained condition | 11b | reserved |
| Bits           | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 00b            | 1024 elements(4096bytes)Default value                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 01b            | 512 elements(2048bytes)                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 10b            | 256 elements(1024bytes)For resource-constrained condition          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |
| 11b            | reserved                                                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           |         |     |                                           |     |                                                                    |     |                                                           |     |          |

| Offset: 0x0010 |            |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1              | R/W        | 0x0         | <p>Host Controller Reset</p> <p>This control bit is used by software to reset the host controller. The effects of this on Root Hub registers are similar to a Chip Hardware Reset.</p> <p>When software writes a one to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports.</p> <p>All operational registers, including port registers and port state machines are set to their initial values. Port ownership reverts to the companion host controller(s). Software must reinitialize the host controller as described in Section 4.1 of the CHEI Specification in order to return the host controller to an operational state.</p> <p>This bit is set to zero by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.</p> <p>Software should not set this bit to a one when the HC Halted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior.</p> |
| 0              | R/W        | 0x0         | <p>Run/Stop</p> <p>When set to a 1, the Host Controller proceeds with execution of the schedule. When set to 0, the Host Controller completes the current and any actively pipelined transactions on the USB and then halts. The Host Controller must halt within 16 micro-frames after software clears this bit.</p> <p>The HC Halted bit indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.</p> <p>Software must not write a one to this field unless the Host Controller is in the Halt State.</p> <p>The default value is 0x0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 9.6.5.7 0x0014 EHCI USB Status Register (Default Value:0x0000\_1000)

| Offset: 0x0014 |            |             | Register Name: USBSTS        |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31:16          | /          | /           | /                            |
| 15             | R          | 0x0         | Asynchronous Schedule Status |

| Offset: 0x0014 |            |             | Register Name: USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | The bit reports the current real status of Asynchronous Schedule. If this bit is a zero then the status of the Asynchronous Schedule is disabled. If this bit is a one then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0).                          |
| 14             | R          | 0x0         | Periodic Schedule Status<br>The bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled. If this bit is a one then the status of the Periodic Schedule is enabled. The Host Controller is not required to <i>immediately</i> disable or enable the Periodic Schedule when software transitions the <i>Periodic Schedule Enable</i> bit in the USBCMD register. When this bit and the <i>Periodic Schedule Enable</i> bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0). |
| 13             | R          | 0x0         | Reclamation<br>This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12             | R          | 0x1         | HC Halted<br>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller Sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller Hardware (e.g. internal error).<br>The default value is '1'.                                                                                                                                                                                                                                                                                      |
| 11:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5              | R/WC       | 0x0         | Interrupt on Async Advance<br>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.                                                                                                                                                                                                                                                           |
| 4              | R/WC       | 0x0         | Host System Error<br>The Host Controller set this bit to 1 when a serious error occurs during a host system access involving the Host Controller module. When this error occurs, the Host Controller clears the Run/Stop bit in the Command register to prevent further execution of the scheduled TDs.                                                                                                                                                                                                                                                                                    |
| 3              | R/WC       | 0x0         | Frame List Rollover                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0x0014 |            |             | Register Name: USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX [12] toggles.                                                                                   |
| 2              | R/WC       | 0x0         | Port Change Detect<br>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to zero has a change bit transition from a zero to a one or a Force Port Resume bit transition from a zero to a one as a result of a J-K transition detected on a suspended port. This bit will also be set as a result of the Connect Status Chang being set to a one after system software has relinquished ownership of a connected port by writing a one to a port's Port Owner bit. |
| 1              | R/WC       | 0x0         | USB Error Interrupt(USBERRINT)<br>The Host Controller sets this bit to 1 when completion of USB transaction results in an error condition(e.g. error counter underflow).If the TD on which the error interrupt occurred also had its IOC bit set, both.<br>This bit and USBINT bit are set.                                                                                                                                                                                                                 |
| 0              | R/WC       | 0x0         | USB Interrupt(USBINT)<br>The Host Controller sets this bit to a one on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.<br>The Host Controller also sets this bit to 1 when a short packet is detected (actual number of bytes received was less than the expected number of bytes)                                                                                                                                                  |

#### 9.6.5.8 0x0018 EHCI USB Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: USBINTR                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                      |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                |
| 5              | R/W        | 0x0         | Interrupt on Async Advance Enable<br>When this bit is 1, and the Interrupt on Async Advance bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the Interrupt on Async Advance bit. |

| Offset: 0x0018 |            |             | Register Name: USBINTR                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | Host System Error Enable<br>When this bit is 1, and the Host System Error Status bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Host System Error bit.               |
| 3              | R/W        | 0x0         | Frame List Rollover Enable<br>When this bit is 1, and the Frame List Rollover bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit.                |
| 2              | R/W        | 0x0         | Port Change Interrupt Enable<br>When this bit is 1, and the Port Chang Detect bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Port Chang Detect bit.                  |
| 1              | R/W        | 0x0         | USB Error Interrupt Enable<br>When this bit is 1, and the USBERRINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBERRINT bit. |
| 0              | R/W        | 0x0         | USB Interrupt Enable<br>When this bit is 1, and the USBINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBINT bit              |

#### 9.6.5.9 0x001C EHCI Frame Index Register (Default Value:0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: FRINDEX                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13:0           | R/W        | 0           | Frame Index<br>The value in this register increment at the end of each time frame (e.g. micro-frame). Bits[N:3] are used for the Frame List current index. It means that each location of the frame list is accessed 8 times (frames or Micro-frames) before moving to the next index.<br>The following illustrates values of N based on the value of the Frame List Size field in the USBCMD register. |

| Offset: 0x001C |            |             | Register Name: FRINDEX  |                 |   |
|----------------|------------|-------------|-------------------------|-----------------|---|
| Bit            | Read/Write | Default/Hex | Description             |                 |   |
|                |            |             | USBCMD[Frame List Size] | Number Elements | N |
|                |            | 00b         | 1024                    | 12              |   |
|                |            | 01b         | 512                     | 11              |   |
|                |            | 10b         | 256                     | 10              |   |
|                |            | 11b         | Reserved                |                 |   |


**NOTE**

This register must be written as a DWord. Byte writes produce undefined results.

#### 9.6.5.10 0x0024 EHCI Periodic Frame List Base Address Register (Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: PERIODICLISTBASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |   |
| 31:12          | R/W        | 0x0         | Base Address<br>These bits correspond to memory address signals [31:12], respectively.<br>This register contains the beginning address of the Periodic Frame List in the system memory.<br>System software loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4 Kbyte aligned. The contents of this register are combined with the Frame Index Register (FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence. | / | / |
| 11:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | / | / |


**NOTE**

Writes must be Dword Writes.

### 9.6.5.11 0x0028 EHCI Current Asynchronous List Address Register (Default Value:0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: ASYNCLISTADDR                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                      |
| 31:5           | R/W        | 0x0         | <p>Link Pointer (LP)</p> <p>This field contains the address of the next asynchronous queue head to be executed.</p> <p>These bits correspond to memory address signals [31:5], respectively.</p> |
| 4:0            | /          | /           | /                                                                                                                                                                                                |


**NOTE**

Write must be DWord Writes.

### 9.6.5.12 0x0050 EHCI Configure Flag Register (Default Value:0x0000\_0000)

| Offset: 0x0050 |                                                                                                            |             | Register Name: CONFIGFLAG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |   |                                                                                                            |   |                                                                             |
|----------------|------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                 | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |         |   |                                                                                                            |   |                                                                             |
| 31:1           | /                                                                                                          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                                                                                            |   |                                                                             |
| 0              | R/W                                                                                                        | 0x0         | <p>Configure Flag (CF)</p> <p>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic as follow:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Port routing control logic default-routs each port to an implementation dependent classic host controller.</td> </tr> <tr> <td>1</td> <td>Port routing control logic default-routs all ports to this host controller.</td> </tr> </tbody> </table> <p>The default value of this field is '0'.</p> | Value | Meaning | 0 | Port routing control logic default-routs each port to an implementation dependent classic host controller. | 1 | Port routing control logic default-routs all ports to this host controller. |
| Value          | Meaning                                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                            |   |                                                                             |
| 0              | Port routing control logic default-routs each port to an implementation dependent classic host controller. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                            |   |                                                                             |
| 1              | Port routing control logic default-routs all ports to this host controller.                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                            |   |                                                                             |


**NOTE**

This register is not used in the normal implementation.

## 9.6.5.13 0x0054 EHCI Port Status and Control Register (Default Value:0x0000\_2000)

| Offset: 0x0054 |                                           |             | Register Name: PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
|----------------|-------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|-------|-------------------------------------------|-------|--------------|-------|--------------|-------|--------------|-------|-------------|-------|-------------------|-------------|----------|
| Bit            | Read/Write                                | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 31:22          | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 21             | R/W                                       | 0x0         | <p>Wake on Disconnect Enable (WKDSCNNT_E)<br/>Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br/>This field is zero if Port Power is zero.<br/>The default value in this field is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 20             | R/W                                       | 0x0         | <p>Wake on Connect Enable (WKCNNT_E)<br/>Writing this bit to a one enable the port to be sensitive to device connects as wake-up events.<br/>This field is zero if Port Power is zero.<br/>The default value in this field is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 19:16          | R/W                                       | 0x0         | <p>Port Test Control<br/>The value in this field specifies the test mode of the port. The encoding of the test mode bits are as follows:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Test Mode</th></tr> </thead> <tbody> <tr> <td>0000b</td><td>The port is NOT operating in a test mode.</td></tr> <tr> <td>0001b</td><td>Test J_STATE</td></tr> <tr> <td>0010b</td><td>Test K_STATE</td></tr> <tr> <td>0011b</td><td>Test SEO_NAK</td></tr> <tr> <td>0100b</td><td>Test Packet</td></tr> <tr> <td>0101b</td><td>Test FORCE_ENABLE</td></tr> <tr> <td>0110b-1111b</td><td>Reserved</td></tr> </tbody> </table> <p>The default value in this field is '0000b'.</p> | Bits | Test Mode | 0000b | The port is NOT operating in a test mode. | 0001b | Test J_STATE | 0010b | Test K_STATE | 0011b | Test SEO_NAK | 0100b | Test Packet | 0101b | Test FORCE_ENABLE | 0110b-1111b | Reserved |
| Bits           | Test Mode                                 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0000b          | The port is NOT operating in a test mode. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0001b          | Test J_STATE                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0010b          | Test K_STATE                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0011b          | Test SEO_NAK                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0100b          | Test Packet                               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0101b          | Test FORCE_ENABLE                         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0110b-1111b    | Reserved                                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 15:14          | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 13             | R/W                                       | 0x1         | <p>Port Owner<br/>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.<br/>System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.<br/>Default Value = 1b.</p>                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 12             | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |

| Offset: 0x0054 |            |                                              | Register Name: PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
|----------------|------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|----------------|-----|-----|-------------------------------------------|-----|---------|-------------------------------------------|-----|---------|----------------------------------------------|-----|-----------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 11:10          | R          | 0x0                                          | <p>Line Status</p> <p>These bits reflect the current logical levels of the D+ (bit11) and D- (bit10) signal lines. These bits are used for detection of low-speed USB devices prior to port reset and enable sequence. This read only field is valid only when the port enable bit is zero and the current connect status bit is set to a one.</p> <p>The encoding of the bits are:</p> <table border="1"> <thead> <tr> <th>Bit[11:10]</th><th>USB State</th><th>Interpretation</th></tr> </thead> <tbody> <tr> <td>00b</td><td>SEO</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr> <td>10b</td><td>J-state</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr> <td>01b</td><td>K-state</td><td>Low-speed device, release ownership of port.</td></tr> <tr> <td>11b</td><td>Undefined</td><td>Not Low-speed device, perform EHCI reset.</td></tr> </tbody> </table> <p>This value of this field is undefined if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                              | Bit[11:10] | USB State | Interpretation | 00b | SEO | Not Low-speed device, perform EHCI reset. | 10b | J-state | Not Low-speed device, perform EHCI reset. | 01b | K-state | Low-speed device, release ownership of port. | 11b | Undefined | Not Low-speed device, perform EHCI reset. |
| Bit[11:10]     | USB State  | Interpretation                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 00b            | SEO        | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 10b            | J-state    | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 01b            | K-state    | Low-speed device, release ownership of port. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 11b            | Undefined  | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 9              | /          | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 8              | R/W        | 0x0                                          | <p>Port Reset</p> <p>1=Port is in Reset. 0=Port is not in Reset. Default value = 0.</p> <p>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes.</p> <p><b>Note: When software writes this bit to a one , it must also write a zero to the Port Enable bit.</b></p> <p>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2 milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state with 2ms of software writing this bit to a zero.</p> |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |

| Offset: 0x0054              |            |             | Register Name: PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                             |            |    |         |    |        |    |         |
|-----------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------|----|---------|----|--------|----|---------|
| Bit                         | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             |            |    |         |    |        |    |         |
|                             |            |             | <p>The HC Halted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HC Halted bit is a one.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                             |            |    |         |    |        |    |         |
| 7                           | R/W        | 0x0         | <p>Suspend</p> <p>Port Enabled Bit and Suspend bit of this register define the port states as follows:</p> <table border="1"> <thead> <tr> <th>Bits[Port Enables, Suspend]</th><th>Port State</th></tr> </thead> <tbody> <tr> <td>0x</td><td>Disable</td></tr> <tr> <td>10</td><td>Enable</td></tr> <tr> <td>11</td><td>Suspend</td></tr> </tbody> </table> <p>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspend and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.</p> <p>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:</p> <ul style="list-style-type: none"> <li>① Software sets the Force Port Resume bit to a zero(from a one).</li> <li>② Software sets the Port Reset bit to a one(from a zero).</li> </ul> <p>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.</p> <p>This field is zero if Port Power is zero.</p> <p>The default value in this field is '0'.</p> | Bits[Port Enables, Suspend] | Port State | 0x | Disable | 10 | Enable | 11 | Suspend |
| Bits[Port Enables, Suspend] | Port State |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 0x                          | Disable    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 10                          | Enable     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 11                          | Suspend    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 6                           | R/W        | 0x0         | <p>Force Port Resume</p> <p>1 = Resume detected/driven on port. 0 = No resume (K-state) detected/driven on port. Default value = 0.</p> <p>This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined.</p> <p>Software sets this bit to 1 to drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             |            |    |         |    |        |    |         |

| Offset: 0x0054 |            |             | Register Name: PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>To a one, the host controller must not set the Port Change Detect bit.</p> <p>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero.</p> <p>This field is zero if Port Power is zero.</p> |
| 5              | R/WC       | 0x0         | <p>Over-current Change</p> <p>This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4              | R          | 0x0         | <p>Over-current Active</p> <p>0 = This port does not have an over-current condition</p> <p>1 = This port currently has an over-current condition</p> <p>This bit will automatically transition from a one to a zero when the over current condition is removed.</p> <p>The default value of this bit is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3              | R/WC       | 0x0         | <p>Port Enable/Disable Change</p> <p>1 = Port enabled/disabled status has changed</p> <p>0 = No change</p> <p>For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification for the definition of a Port Error). Software clears this bit by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                |
| 2              | R/W        | 0x0         | <p>Port Enabled/Disabled</p> <p>1=Enable</p> <p>0=Disable</p> <p>Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0x0054 |            |             | Register Name: PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>Ports can be disabled by either a fault condition(disconnect event or other fault condition) or by host software. Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events.</p> <p>When the port is disabled, downstream propagation of data is blocked on this port except for reset.</p> <p>The default value of this field is '0'.</p> <p>This field is zero if Port Power is zero.</p>                                                                                 |
| 1              | R/WC       | 0x0         | <p>Connect Status Change<br/>1=Change in Current Connect Status<br/>0=No change</p> <p>Indicates a change has occurred in the current connect status of the port. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be “setting” an already-set bit. Software sets this bit to 0 by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p> |
| 0              | R          | 0x0         | <p>Current Connect Status</p> <p>Device is present on port when the value of this field is a one, and no device is present on port when the value of this field is a zero.</p> <p>This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change(Bit 1) to be set.</p> <p>This field is zero if Port Power zero.</p>                                                                                                                                                                                                           |



#### NOTE

This register is only reset by hardware or in response to a host controller reset.

## 9.6.6 OHCI Register Description

### 9.6.6.1 0x0404 OHCI Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0404 |                |     | Register Name: HcRevision |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
|----------------|----------------|-----|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|-----------|-----|----------------|-----|------------|
| Bit            | Read/Write     |     | Default/Hex               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |          |     |           |     |                |     |            |
|                | HCD            | HC  |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
| 31:11          | /              | /   | /                         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |     |          |     |           |     |                |     |            |
| 10             | R/W            | R   | 0x0                       | <p><b>RemoteWakeupEnable</b><br/> This bit is used by HCD to enable or disable the remote wakeup feature upon the detection of upstream resume signaling. When this bit is set and the <b>ResumeDetected</b> bit in <b>HcInterruptStatus</b> is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |          |     |           |     |                |     |            |
| 9              | R/W            | R/W | 0x0                       | <p><b>RemoteWakeupConnected</b><br/> This bit indicates whether HC supports remote wakeup signaling. If remote wakeup is supported and used by the system, it is the responsibility of system firmware to set this bit during POST. HC clear the bit upon a hardware reset but does not alter it upon a software reset. Remote wakeup signaling of the host system is host-bus-specific and is not described in this specification.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |
| 8              | R/W            | R   | 0x0                       | <p><b>InterruptRouting</b><br/> This bit determines the routing of interrupts generated by events registered in <b>HcInterruptStatus</b>. If clear, all interrupt are routed to the normal host bus interrupt mechanism. If set interrupts are routed to the System Management Interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |     |          |     |           |     |                |     |            |
| 7:6            | R/W            | R/W | 0x0                       | <p><b>HostControllerFunctionalState for USB</b></p> <table border="1"> <tr> <td>00b</td><td>USBReset</td></tr> <tr> <td>01b</td><td>USBResume</td></tr> <tr> <td>10b</td><td>USBOperational</td></tr> <tr> <td>11b</td><td>USBSuspend</td></tr> </table> <p>A transition to <b>USBOperational</b> from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the <b>StartOfFrame</b> field of <b>HcInterruptStatus</b>.</p> <p>This field may be changed by HC only when in the <b>USBSUSPEND</b> state. HC may move from the <b>USBSUSPEND</b> state to the <b>USBRESUME</b> state after detecting the resume signaling from a downstream port.</p> <p>HC enters <b>USBSUSPEND</b> after a software reset, whereas it enters <b>USBRESET</b> after a hardware reset. The latter also resets the Root</p> | 00b | USBReset | 01b | USBResume | 10b | USBOperational | 11b | USBSuspend |
| 00b            | USBReset       |     |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
| 01b            | USBResume      |     |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
| 10b            | USBOperational |     |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
| 11b            | USBSuspend     |     |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |

| Offset: 0x0404 |                                         |    | Register Name: HcRevision |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |
|----------------|-----------------------------------------|----|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|
| Bit            | Read/Write                              |    | Default/Hex               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |                                         |   |     |
|                | HCD                                     | HC |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |
|                |                                         |    |                           | Hub and asserts subsequent reset signaling to downstream ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |
| 5              | R/W                                     | R  | 0x0                       | <p><b>BulkListEnable</b></p> <p>This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by HCD, the processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <i>HcBulkCurrentED</i> is pointing to an ED to be removed, HCD must advance the pointer by updating <i>HcBulkCurrentED</i> before re-enabling processing of the list.</p>                                                                                                                                                          |      |                                         |   |     |
| 4              | R/W                                     | R  | 0x0                       | <p><b>ControlListEnable</b></p> <p>This bit is set to enable the processing of the Control list in the next Frame. If cleared by HCD, the processing of the Control list does not occur after the next SOF. HC must check this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <i>HcControlCurrentED</i> is pointing to an ED to be removed, HCD must advance the pointer by updating <i>HcControlCurrentED</i> before re-enabling processing of the list.</p>                                                                                                                                       |      |                                         |   |     |
| 3              | R/W                                     | R  | 0x0                       | <p><b>IsochronousEnable</b></p> <p>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists. Setting this bit is guaranteed to take effect in the next Frame (not the current Frame).</p>                                                                                                      |      |                                         |   |     |
| 2              | R/W                                     | R  | 0x0                       | <p><b>PeriodicListEnable</b></p> <p>This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.</p>                                                                                                                                                                                                                                                                                                                                                                         |      |                                         |   |     |
| 1:0            | R/W                                     | R  | 0x0                       | <p><b>ControlBulkServiceRatio</b></p> <p>This specifies the service ratio between Control and Bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value.</p> <table border="1"> <tr> <td>CBSR</td><td>No. of Control EDs Over Bulk EDs Served</td></tr> <tr> <td>0</td><td>1:1</td></tr> </table> | CBSR | No. of Control EDs Over Bulk EDs Served | 0 | 1:1 |
| CBSR           | No. of Control EDs Over Bulk EDs Served |    |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |
| 0              | 1:1                                     |    |                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |

| Offset: 0x0404            |            |    | Register Name: HcRevision |             |
|---------------------------|------------|----|---------------------------|-------------|
| Bit                       | Read/Write |    | Default/Hex               | Description |
|                           | HCD        | HC |                           |             |
|                           |            |    | 1                         | 2:1         |
|                           |            |    | 2                         | 3:1         |
|                           |            |    | 3                         | 4:1         |
| The default value is 0x0. |            |    |                           |             |

#### 9.6.6.2 0x0408 OHCI Command Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0408 |            |     | Register Name: HcCommandStatus |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-----|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC  |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:18          | /          | /   | 0x0                            | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 17:16          | R          | R/W | 0x0                            | <b>SchedulingOverrunCount</b><br>These bits are incremented on each scheduling overrun error. It is initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if <b>SchedulingOverrun</b> in <i>HcInterruptStatus</i> has already been set. This is used by HCD to monitor any persistent scheduling problem.                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:4           | /          | /   | /                              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 3              | R/W        | R/W | 0x0                            | <b>OwnershipChangeRequest</b><br>This bit is set by an OS HCD to request a change of control of the HC. When set HC will set the <b>OwnershipChange</b> field in <i>HcInterruptStatus</i> . After the changeover, this bit is cleared and remains so until the next request from OS HCD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2              | R/W        | R/W | 0x0                            | <b>BulkListFilled</b><br>This bit is used to indicate whether there are any TDs on the Bulk list. It is set by HCD whenever it adds a TD to an ED in the Bulk list. When HC begins to process the head of the Bulk list, it checks BLF. As long as <b>BulkListFilled</b> is 0, HC will not start processing the Bulk list. If <b>BulkListFilled</b> is 1, HC will start processing the Bulk list and will set BF to 0. If HC finds a TD on the list, then HC will set <b>BulkListFilled</b> to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set <b>BulkListFilled</b> , then <b>BulkListFilled</b> will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop. |
| 1              | R/W        | R/W | 0x0                            | <b>ControlListFilled</b><br>This bit is used to indicate whether there are any TDs on the Control list. It is set by HCD whenever it adds a TD to an ED in the Control list.<br>When HC begins to process the head of the Control list, it checks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Offset: 0x0408 |            |     |             | Register Name: HcCommandStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |     |             | CLF. As long as <b>ControlListFilled</b> is 0, HC will not start processing the Control list. If CF is 1, HC will start processing the Control list and will set <b>ControlListFilled</b> to 0. If HC finds a TD on the list, then HC will set <b>ControlListFilled</b> to 1 causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set <b>ControlListFilled</b> , then <b>ControlListFilled</b> will still be 0 when HC completes processing the Control list and Control list processing will stop.                                                          |
| 0              | R/W        | R/E | 0x0         | <p><b>HostControllerReset</b></p> <p>This bit is by HCD to initiate a software reset of HC. Regardless of the functional state of HC, it moves to the USBSuspend state in which most of the operational registers are reset except those stated otherwise; e.g, the InterruptRouting field of HcControl, and no Host bus accesses are allowed. This bit is cleared by HC upon the completion of the reset operation. The reset operation must be completed within 10 ms. This bit, when set, should not cause a reset to the Root Hub and no subsequent reset signaling should be asserted to its downstream ports.</p> |

#### 9.6.6.3 0x040C OHCI Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x040C |            |     |             | Register Name: HcInterruptStatus                                                                                                                                                                                                                            |
|----------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                 |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                             |
| 31:7           | /          | /   | /           | /                                                                                                                                                                                                                                                           |
| 6              | R/W        | R/W | 0x0         | <p><b>RootHubStatusChange</b></p> <p>This bit is set when the content of <i>HcRhStatus</i> or the content of any of <i>HcRhPortStatus</i>[<b>NumberOfDownstreamPort</b>] has changed.</p>                                                                   |
| 5              | R/W        | R/W | 0x0         | <p><b>FrameNumberOverflow</b></p> <p>This bit is set when the MSb of <i>HcFmNumber</i> (bit 15) changes value, from 0 to 1 or from 1 to 0, and after <i>HccaFrameNumber</i> has been updated.</p>                                                           |
| 4              | R/W        | R/W | 0x0         | <p><b>UnrecoverableError</b></p> <p>This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.</p> |
| 3              | R/W        | R/W | 0x0         | <p><b>ResumeDetected</b></p> <p>This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to</p>                                                                                |

| Offset: 0x040C |            |     |             | Register Name: HcInterruptStatus                                                                                                                                                                                                                                                                                   |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                        |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                    |
|                |            |     |             | resume signaling causing this bit to be set. This bit is not set when HCD sets the USBRseume state.                                                                                                                                                                                                                |
| 2              | R/W        | R/W | 0x0         | <p><b>StartofFrame</b></p> <p>This bit is set by HC at each start of frame and after the update of HccaFrameNumber. HC also generates a SOF token at the same time.</p>                                                                                                                                            |
| 1              | R/W        | R/W | 0x0         | <p><b>WritebackDoneHead</b></p> <p>This bit is set immediately after HC has written <i>HcDoneHead</i> to <i>HccaDoneHead</i>. Further updates of the <i>HccaDoneHead</i> will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of <i>HccaDoneHead</i>.</p> |
| 0              | R/W        | R/W | 0x0         | <p><b>SchedulingOverrun</b></p> <p>This bit is set when the USB schedule for the current Frame overruns and after the update of <i>HccaFrameNumber</i>. A scheduling overrun will also cause the <b>SchedulingOverrunCount</b> of <i>HcCommandStatus</i> to be incremented.</p>                                    |

#### 9.6.6.4 0x0410 OHCI Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0410 |                                                            |    |             | Register Name: HcInterruptEnable Register                                                                                                                                                                                                                     |   |         |   |                                                            |
|----------------|------------------------------------------------------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|------------------------------------------------------------|
| Bit            | Read/Write                                                 |    | Default/Hex | Description                                                                                                                                                                                                                                                   |   |         |   |                                                            |
|                | HCD                                                        | HC |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 31             | R/W                                                        | R  | 0x0         | <p><b>MasterInterruptEnable</b></p> <p>A ‘0’ written to this field is ignored by HC. A ‘1’ written to this field enables interrupt generation due to events specified in the other bits of this register. This is used by HCD as Master Interrupt Enable.</p> |   |         |   |                                                            |
| 30:7           | /                                                          | /  | /           | <b>RootHubStatusChange Interrupt Enable</b>                                                                                                                                                                                                                   |   |         |   |                                                            |
| 6              | R/W                                                        | R  | 0x0         | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Root Hub Status Change;</td></tr> </table>                                                                                                      | 0 | Ignore; | 1 | Enable interrupt generation due to Root Hub Status Change; |
| 0              | Ignore;                                                    |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 1              | Enable interrupt generation due to Root Hub Status Change; |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 5              | R/W                                                        | R  | 0x0         | <p><b>FrameNumberOverflow Interrupt Enable</b></p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Frame Number Over Flow;</td></tr> </table>                                                   | 0 | Ignore; | 1 | Enable interrupt generation due to Frame Number Over Flow; |
| 0              | Ignore;                                                    |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 1              | Enable interrupt generation due to Frame Number Over Flow; |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 4              | R/W                                                        | R  | 0x0         | <p><b>UnrecoverableError Interrupt Enable</b></p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Unrecoverable Error;</td></tr> </table>                                                       | 0 | Ignore; | 1 | Enable interrupt generation due to Unrecoverable Error;    |
| 0              | Ignore;                                                    |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 1              | Enable interrupt generation due to Unrecoverable Error;    |    |             |                                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 3              | R/W                                                        | R  | 0x0         | <b>ResumeDetected Interrupt Enable</b>                                                                                                                                                                                                                        |   |         |   |                                                            |

| Offset: 0x0410 |            |    | Register Name: HcInterruptEnable Register |                                           |                                                        |  |  |  |
|----------------|------------|----|-------------------------------------------|-------------------------------------------|--------------------------------------------------------|--|--|--|
| Bit            | Read/Write |    | Default/Hex                               | Description                               |                                                        |  |  |  |
|                | HCD        | HC |                                           |                                           |                                                        |  |  |  |
| 2              | R/W        | R  | 0x0                                       | 0                                         | Ignore;                                                |  |  |  |
|                |            |    |                                           | 1                                         | Enable interrupt generation due to Resume Detected;    |  |  |  |
| 1              | R/W        | R  | 0x0                                       | <b>StartofFrame Interrupt Enable</b>      |                                                        |  |  |  |
|                |            |    |                                           | 0                                         | Ignore;                                                |  |  |  |
| 0              | R/W        | R  | 0x0                                       | <b>WritebackDoneHead Interrupt Enable</b> |                                                        |  |  |  |
|                |            |    |                                           | 0                                         | Ignore;                                                |  |  |  |
|                |            |    |                                           | <b>SchedulingOverrun Interrupt Enable</b> |                                                        |  |  |  |
|                |            |    |                                           | 0                                         | Ignore;                                                |  |  |  |
|                |            |    |                                           | 1                                         | Enable interrupt generation due to Scheduling Overrun; |  |  |  |

#### 9.6.6.5 0x0414 OHCI Interrupt Disable Register (Default Value: 0x0000\_0000)

| Offset: 0x0414 |            |    | Register Name: HcInterruptDisable Register |                                                                                                                                                                                                                        |                                                     |
|----------------|------------|----|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex                                | Description                                                                                                                                                                                                            |                                                     |
|                | HCD        | HC |                                            |                                                                                                                                                                                                                        |                                                     |
| 31             | R/W        | R  | 0x0                                        | <b>MasterInterruptEnable</b>                                                                                                                                                                                           |                                                     |
|                |            |    |                                            | A written '0' to this field is ignored by HC. A '1' written to this field disables interrupt generation due events specified in the other bits of this register. This field is set after a hardware or software reset. |                                                     |
| 30:7           | /          | /  | /                                          | /                                                                                                                                                                                                                      |                                                     |
| 6              | R/W        | R  | 0x0                                        | <b>RootHubStatusChange Interrupt Disable</b>                                                                                                                                                                           |                                                     |
|                |            |    |                                            | 0                                                                                                                                                                                                                      | Ignore;                                             |
| 5              | R/W        | R  | 0x0                                        | <b>FrameNumberOverflow Interrupt Disable</b>                                                                                                                                                                           |                                                     |
|                |            |    |                                            | 0                                                                                                                                                                                                                      | Ignore;                                             |
| 4              | R/W        | R  | 0x0                                        | <b>UnrecoverableError Interrupt Disable</b>                                                                                                                                                                            |                                                     |
|                |            |    |                                            | 0                                                                                                                                                                                                                      | Ignore;                                             |
| 3              | R/W        | R  | 0x0                                        | <b>ResumeDetected Interrupt Disable</b>                                                                                                                                                                                |                                                     |
|                |            |    |                                            | 0                                                                                                                                                                                                                      | Ignore;                                             |
| 2              | R/W        | R  | 0x0                                        | <b>StartofFrame Interrupt Disable</b>                                                                                                                                                                                  |                                                     |
|                |            |    |                                            | 0                                                                                                                                                                                                                      | Ignore;                                             |
|                |            |    |                                            | 1                                                                                                                                                                                                                      | Disable interrupt generation due to Start of Flame; |

| Offset: 0x0414 |                                                           |    |             | Register Name: HlInterruptDisable Register                                                                                                              |
|----------------|-----------------------------------------------------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                |    | Default/Hex | Description                                                                                                                                             |
|                | HCD                                                       | HC |             |                                                                                                                                                         |
| 1              | R/W                                                       | R  | 0x0         | <b>WritebackDoneHead Interrupt Disable</b>                                                                                                              |
|                |                                                           |    |             | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Write back Done Head;</td></tr> </table> |
| 0              | Ignore;                                                   |    |             |                                                                                                                                                         |
| 1              | Disable interrupt generation due to Write back Done Head; |    |             |                                                                                                                                                         |
| 0              | R/w                                                       | R  | 0x0         | <b>SchedulingOverrun Interrupt Disable</b>                                                                                                              |
|                |                                                           |    |             | <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Scheduling Overrun;</td></tr> </table>   |
| 0              | Ignore;                                                   |    |             |                                                                                                                                                         |
| 1              | Disable interrupt generation due to Scheduling Overrun;   |    |             |                                                                                                                                                         |

#### 9.6.6.6 0x0418 OHCI HCCA Register (Default Value: 0x0000\_0000)

| Offset: 0x0418 |            |    |             | Register Name: HcHCCA                                                                                                                                                                                                                           |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                     |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                 |
| 31:8           | R/W        | R  | 0x0         | <b>HCCA[31:8]</b><br>This is the base address of the Host Controller Communication Area. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver. |
| 7:0            | R          | R  | 0x0         | <b>HCCA[7:0]</b><br>The alignment restriction in HcHCCA register is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes, therefore, bits 0 through 7 must always return 0 when read.         |

#### 9.6.6.7 0x041C OHCI Period Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x041C |            |     |             | Register Name: HcPeriodCurrentED[PCED]                                                                                                                                                                                                                                                                                             |
|----------------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                        |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                    |
| 31:4           | R          | R/W | 0x0         | <b>PCED[31:4]</b><br>This is used by HC to point to the head of one of the Periodic list which will be processed in the current Frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading. |
| 3:0            | R          | R   | 0x0         | <b>PCED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                            |

### 9.6.6.8 0x0420 OHCI Control Head ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0420 |            |    |             | Register Name: HcControlHeadED[CHED]                                                                                                                                                                                                                                           |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                    |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                |
| 31:4           | R/W        | R  | 0x0         | <b>EHCD[31:4]</b><br>The HcControlHeadED register contains the physical address of the first Endpoint Descriptor of the Control list. HC traverse the Control list starting with the HcControlHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0            | R          | R  | 0x0         | <b>EHCD[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                        |

### 9.6.6.9 0x0424 OHCI Control Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0424 |            |     |             | Register Name: HcControlCurrentED[CCED]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:4           | R/W        | R/W | 0x0         | <b>CCED[31:4]</b><br>The pointer is advanced to the next ED after serving the present one. HC will continue processing the list from where it left off in the last Frame. When it reaches the end of the Control list, HC checks the ControlListFilled of in HcCommandStatus. If set, it copies the content of HcControlHeadED to HcControlCurrentED and clears the bit. If not set, it does nothing.<br>HCD is allowed to modify this register only when the ControlListEnable of HcControl is cleared. When set, HCD only reads the instantaneous value of this register. Initially, this is set to zero to indicate the end of the Control list. |
| 3:0            | R          | R   | 0x0         | <b>CCED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 9.6.6.10 0x0428 OHCI Bulk Head ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0428 |            |    |             | Register Name: HcBulkHeadED[BHED]                                                                                                                                                                                                                                   |
|----------------|------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                         |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                     |
| 31:4           | R/W        | R  | 0x0         | <b>BHED[31:4]</b><br>The HcBulkHeadED register contains the physical address of the first Endpoint Descriptor of the Bulk list. HC traverses the Bulk list starting with the HcBulkHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0            | R          | R  | 0x0         | <b>BHED[3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                             |

#### 9.6.6.11 0x042C OHCI Bulk Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x042C |            |     |             | Register Name: HcBulkCurrentED[BCED]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:4           | R/W        | R/W | 0x0         | <b>BulkCurrentED[31:4]</b><br>This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last Frame. When it reaches the end of the Bulk list, HC checks the <b>ControlListFilled</b> of HcControl. If set, it copies the content of <i>HcBulkHeadED</i> to <i>HcBulkCurrentED</i> and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the <b>BulkListEnable</b> of <i>HcControl</i> is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to zero to indicate the end of the Bulk list. |
| 3:0            | R          | R   | 0x0         | <b>BulkCurrentED [3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### 9.6.6.12 0x0430 OHCI Done Head Register (Default Value: 0x0000\_0000)

| Offset: 0x0430 |            |     |             | Register Name: HcDoneHead                                                                        |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                      |
|                | HCD        | HC  |             |                                                                                                  |
| 31:4           | R          | R/W | 0x0         | <b>HcDoneHead[31:4]</b><br>When a TD is completed, HC writes the content of <i>HcDoneHead</i> to |

| Offset: 0x0430 |            |    |             | Register Name: HcDoneHead                                                                                                                                                                                                                                         |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                       |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                   |
|                |            |    |             | the NextTD field of the TD. HC then overwrites the content of <i>HcDoneHead</i> with the address of this TD. This is set to zero whenever HC writes the content of this register to HCCA. It also sets the <b>WritebackDoneHead</b> of <i>HcInterruptStatus</i> . |
| 3:0            | R          | R  | 0x0         | <p><b>HcDoneHead[3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                          |

#### 9.6.6.13 0x0434 OHCI Frame Interval Register (Default Value: 0x0000\_2EDF)

| Offset: 0x0434 |            |    |             | Register Name: HcFmInterval Register                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | R  | 0x0         | <p><b>FrameIntervalToggler</b></p> <p>HCD toggles this bit whenever it loads a new value to <b>FrameInterval</b>.</p>                                                                                                                                                                                                                                                                                                                                      |
| 30:16          | R/W        | R  | 0x0         | <p><b>FSLargestDataPacket</b></p> <p>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD.</p>                                                                 |
| 15:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13:0           | R/W        | R  | 0x2edf      | <p><b>FrameInterval</b></p> <p>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the <b>HostControllerReset</b> field of <i>HcCommandStatus</i> as this will cause the HC to reset this field to its nominal value. HCD may choose to restore the stored value upon the completion of the Reset sequence.</p> |

#### 9.6.6.14 0x0438 OHCI Frame Remaining Register (Default Value: 0x0000\_0000)

| Offset: 0x0438 |            |     |             | Register Name: HcFmRemaining                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                         |
| 31             | R          | R/W | 0x0         | <b>FrameRemaining Toggle</b><br>This bit is loaded from the <b>FrameIntervalToggle</b> field of <i>HcFmInterval</i> whenever <b>FrameRemaining</b> reaches 0. This bit is used by HCD for the synchronization between <b>FrameInterval</b> and <b>FrameRemaining</b> .                                                                                                  |
| 30:14          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 13:0           | R          | RW  | 0x0         | <b>FrameRemaining</b><br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the FrameInterval value specified in <i>HcFmInterval</i> at the next bit time boundary. When entering the USBOPERATIONAL state, HC re-loads the content with the FrameInterval of <i>HcFmInterval</i> and uses the updated value from the next SOF. |

#### 9.6.6.15 0x043C OHCI Frame Number Register (Default Value: 0x0000\_0000)

| Offset: 0x043C |            |     |             | Register Name: HcFmNumber                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:16          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15:0           | R          | R/W | 0x0         | <b>FrameNumber</b><br>This is incremented when <i>HcFmRemaining</i> is re-loaded. It will be rolled over to 0x0 after 0xffff. When entering the USBOPERATIONAL state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the <b>FrameNumber</b> at each frame boundary and sent a SOF but before HC reads the first ED in that Frame. After writing to HCCA, HC will set the <b>StartofFrame</b> in <i>HcInterruptStatus</i> . |

#### 9.6.6.16 0x0440 OHCI Periodic Start Register (Default Value: 0x0000\_0000)

| Offset: 0x0440 |            |    |             | Register Name: HcPeriodicStatus                                                                |
|----------------|------------|----|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                    |
|                | HCD        | HC |             |                                                                                                |
| 31:14          | /          | /  | /           | /                                                                                              |
| 13:0           | R/W        | R  | 0x0         | <b>PeriodicStart</b><br>After a hardware reset, this field is cleared. This is then set by HCD |

| Offset: 0x0440 |            |    | Register Name: HcPeriodicStatus |                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|----|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |    |                                 | during the HC initialization. The value is calculated roughly as 10% off from <i>HcFmInterval</i> . A typical value will be 0x2A3F (or 0x3e67). When <i>HcFmRemaining</i> reaches the value specified, processing of the periodic lists will have priority over Control/Bulk processing. HC will therefore start processing the Interrupt list after completing the current Control or Bulk transaction that is in progress. |

#### 9.6.6.17 0x0444 OHCI LS Threshold Register (Default Value: 0x0000\_0628)

| Offset: 0x0444 |            |    | Register Name: HcLSThreshold |                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|----|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex                  | Description                                                                                                                                                                                                                                                                                                                   |
|                | HCD        | HC |                              |                                                                                                                                                                                                                                                                                                                               |
| 31:12          | /          | /  | /                            | /                                                                                                                                                                                                                                                                                                                             |
| 11:0           | R/W        | R  | 0x0628                       | <p><b>LSThreshold</b></p> <p>This field contains a value which is compared to the <b>FrameRemaining</b> field prior to initiating a Low Speed transaction. The transaction is started only if <b>FrameRemaining</b> this field. The value is calculated by HCD with the consideration of transmission and setup overhead.</p> |

#### 9.6.6.18 0x0448 OHCI Root Hub DescriptorA Register (Default Value: 0x0200\_1201)

| Offset: 0x0448 |                                                                        |    | Register Name: HcRhDescriptorA |                                                                                                                                                                                                                                                                                                                                                                                       |          |                                                                        |
|----------------|------------------------------------------------------------------------|----|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------------------------|
| Bit            | Read/Write                                                             |    | Default/Hex                    | Description                                                                                                                                                                                                                                                                                                                                                                           |          |                                                                        |
|                | HCD                                                                    | HC |                                |                                                                                                                                                                                                                                                                                                                                                                                       |          |                                                                        |
| 31:24          | R/W                                                                    | R  | 0x2                            | <p><b>PowerOnToPowerGoodTime[POTPGT]</b></p> <p>This byte specifies the duration HCD has to wait before accessing a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.</p>                                                                                                                         |          |                                                                        |
| 23:13          | /                                                                      | /  | /                              | /                                                                                                                                                                                                                                                                                                                                                                                     |          |                                                                        |
| 12             | R/W                                                                    | R  | 0x1                            | <p><b>NoOverCurrentProtection</b></p> <p>This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the <b>OverCurrentProtectionMode</b> field specifies global or per-port reporting.</p> <table border="1"> <tr> <td><b>0</b></td> <td>Over-current status is reported collectively for all downstream ports.</td> </tr> </table> | <b>0</b> | Over-current status is reported collectively for all downstream ports. |
| <b>0</b>       | Over-current status is reported collectively for all downstream ports. |    |                                |                                                                                                                                                                                                                                                                                                                                                                                       |          |                                                                        |

| Offset: 0x0448 |                                                                                                                                                                                                                                                                                                                                                                                          |    |             | Register Name: HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                                                                                                                                                                                                                               |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|                | HCD                                                                                                                                                                                                                                                                                                                                                                                      | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
|                |                                                                                                                                                                                                                                                                                                                                                                                          |    |             | <p><b>1</b> No overcurrent protection supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 11             | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x0         | <p><b>OverCurrentProtectionMode</b><br/>This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as <b>PowerSwitchingMode</b>. This field is valid only if the <b>NoOverCurrentProtection</b> field is cleared.</p> <table border="1"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>Over-current status is reported on per-port basis.</td></tr> </table>                                                                                                                                                                                                                                         | 0 | Over-current status is reported collectively for all downstream ports. | 1 | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |
| 0              | Over-current status is reported collectively for all downstream ports.                                                                                                                                                                                                                                                                                                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | Over-current status is reported on per-port basis.                                                                                                                                                                                                                                                                                                                                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 10             | R                                                                                                                                                                                                                                                                                                                                                                                        | R  | 0x0         | <p><b>Device Type</b><br/>This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 9              | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x1         | <p><b>PowerSwitchingMode</b><br/>This bit is used to specify how the power switching of the Root Hub ports is controlled. It is implementation-specific. This field is only valid if the <b>NoPowerSwitching</b> field is cleared.</p> <table border="1"> <tr> <td>0</td><td>All ports are powered at the same time.</td></tr> <tr> <td>1</td><td>Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (<b>Set/ClearPortPower</b>). If the port mask is cleared, then the port is controlled only by the global power switch (<b>Set/ClearGlobalPower</b>).</td></tr> </table> | 0 | All ports are powered at the same time.                                | 1 | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |
| 0              | All ports are powered at the same time.                                                                                                                                                                                                                                                                                                                                                  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands ( <b>Set/ClearPortPower</b> ). If the port mask is cleared, then the port is controlled only by the global power switch ( <b>Set/ClearGlobalPower</b> ). |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 8              | R/W                                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x0         | <p><b>NoPowerSwitching</b><br/>These bits are used to specify whether power switching is supported or ports are always powered. It is implementation-specific. When this bit is cleared, the <b>PowerSwitchingMode</b> specifies global or per-port switching.</p> <table border="1"> <tr> <td>0</td><td>Ports are power switched.</td></tr> <tr> <td>1</td><td>Ports are always powered on when the HC is powered on.</td></tr> </table>                                                                                                                                                                                                                                                                                                                 | 0 | Ports are power switched.                                              | 1 | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                                   |
| 0              | Ports are power switched.                                                                                                                                                                                                                                                                                                                                                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:0            | R                                                                                                                                                                                                                                                                                                                                                                                        | R  | 0x01        | <p><b>NumberDownstreamPorts</b><br/>These bits specify the number of downstream ports supported by the Root Hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                                                          |

### 9.6.6.19 0x044C HcRhDescriptorB Register (Default Value: 0x0000\_0000)

| Offset: 0x044C |                                |    |             | Register Name: HcRhDescriptorB Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |          |      |                               |      |                               |     |  |       |                                |
|----------------|--------------------------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
| Bit            | Read/Write                     |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |          |      |                               |      |                               |     |  |       |                                |
|                | HCD                            | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| 31:16          | R/W                            | R  | 0x0         | <p><b>PortPowerControlMask</b></p> <p>Each bit indicates if a port is affected by a global power control command when <b>PowerSwitchingMode</b> is set. When set, the port's power state is only affected by per-port power control (<b>Set/ClearPortPower</b>). When cleared, the port is controlled by the global power switch (<b>Set/ClearGlobalPower</b>). If the device is configured to global switching mode (<b>PowerSwitchingMode</b> = 0 ), this field is not valid.</p> <table border="1"> <tr> <td>Bit0</td><td>Reserved</td></tr> <tr> <td>Bit1</td><td>Ganged-power mask on Port #1.</td></tr> <tr> <td>Bit2</td><td>Ganged-power mask on Port #2.</td></tr> <tr> <td>...</td><td></td></tr> <tr> <td>Bit15</td><td>Ganged-power mask on Port #15.</td></tr> </table> | Bit0 | Reserved | Bit1 | Ganged-power mask on Port #1. | Bit2 | Ganged-power mask on Port #2. | ... |  | Bit15 | Ganged-power mask on Port #15. |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Ganged-power mask on Port #1.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Ganged-power mask on Port #2.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Ganged-power mask on Port #15. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| 15:0           | R/W                            | R  | 0x0         | <p><b>DeviceRemovable</b></p> <p>Each bit is dedicated to a port of the Root Hub. When cleared, the attached device is removable. When set, the attached device is not removable.</p> <table border="1"> <tr> <td>Bit0</td><td>Reserved</td></tr> <tr> <td>Bit1</td><td>Device attached to Port #1.</td></tr> <tr> <td>Bit2</td><td>Device attached to Port #2.</td></tr> <tr> <td>...</td><td></td></tr> <tr> <td>Bit15</td><td>Device attached to Port #15.</td></tr> </table>                                                                                                                                                                                                                                                                                                     | Bit0 | Reserved | Bit1 | Device attached to Port #1.   | Bit2 | Device attached to Port #2.   | ... |  | Bit15 | Device attached to Port #15.   |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Device attached to Port #1.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Device attached to Port #2.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Device attached to Port #15.   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |          |      |                               |      |                               |     |  |       |                                |

### 9.6.6.20 0x0450 HcRhStatus Register (Default Value: 0x0000\_0000)

| Offset: 0x0450 |            |    |             | Register Name: HcRhStatus Register                                                                                                                                                                                                       |
|----------------|------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                              |
|                | HCD        | HC |             |                                                                                                                                                                                                                                          |
| 31             | W          | R  | 0x0         | <p><b>(write)ClearRemoteWakeUpEnable</b></p> <p>Write a '1' clears <b>DeviceRemoteWakeUpEnable</b>. Writing a '0' has no effect.</p>                                                                                                     |
| 30:18          | /          | /  | /           | /                                                                                                                                                                                                                                        |
| 17             | R/W        | R  | 0x0         | <p><b>OverCurrentIndicatorChange</b></p> <p>This bit is set by hardware when a change has occurred to the <b>OverCurrentIndicator</b> field of this register. The HCD clears this bit by writing a '1'. Writing a '0' has no effect.</p> |
| 16             | R/W        | R  | 0x0         | <b>(read)LocalPowerStartusChange</b>                                                                                                                                                                                                     |

| Offset: 0x0450 |                                                          |     |             | Register Name: HcRhStatus Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                          |   |                                                      |
|----------------|----------------------------------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------|---|------------------------------------------------------|
| Bit            | Read/Write                                               |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                                          |   |                                                      |
|                | HCD                                                      | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                          |   |                                                      |
|                |                                                          |     |             | <p>The Root Hub does not support the local power status features, thus, this bit is always read as '0'.</p> <p><b>(write)SetGlobalPower</b></p> <p>In global power mode (<b>PowerSwitchingMode=0</b>), This bit is written to '1' to turn on power to all ports (clear <b>PortPowerStatus</b>). In per-port power mode, it sets <b>PortPowerStatus</b> only on ports whose <b>PortPowerControlMask</b> bit is not set. Writing a '0' has no effect.</p>                                                                                                                                                                      |   |                                                          |   |                                                      |
| 15             | R/W                                                      | R   | 0x0         | <p><b>(read)DeviceRemoteWakeupEnable</b></p> <p>This bit enables a <b>ConnectStatusChange</b> bit as a resume event, causing a USB SUSPEND to USB RESUME state transition and setting the <b>ResumeDetected</b> interrupt.</p> <table border="1"> <tr> <td>0</td><td><b>ConnectStatusChange</b> is not a remote wakeup event.</td></tr> <tr> <td>1</td><td><b>ConnectStatusChange</b> is a remote wakeup event.</td></tr> </table> <p><b>(write)SetRemoteWakeupEnable</b></p> <p>Writing a '1' sets DeviceRemoveWakeupEnable. Writing a '0' has no effect.</p>                                                               | 0 | <b>ConnectStatusChange</b> is not a remote wakeup event. | 1 | <b>ConnectStatusChange</b> is a remote wakeup event. |
| 0              | <b>ConnectStatusChange</b> is not a remote wakeup event. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                          |   |                                                      |
| 1              | <b>ConnectStatusChange</b> is a remote wakeup event.     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                          |   |                                                      |
| 14:2           | /                                                        | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                                                          |   |                                                      |
| 1              | R                                                        | R/W | 0x0         | <p><b>OverCurrentIndicator</b></p> <p>This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal.</p> <p>If per-port overcurrent protection is implemented this bit is always '0'</p>                                                                                                                                                                                                                                                                                                                        |   |                                                          |   |                                                      |
| 0              | R/W                                                      | R   | 0x0         | <p><b>(Read)LocalPowerStatus</b></p> <p>When read, this bit returns the LocalPowerStatus of the Root Hub. The Root Hub does not support the local power status feature; thus, this bit is always read as '0'.</p> <p><b>(Write)ClearGlobalPower</b></p> <p>When write, this bit is operated as the ClearGlobalPower. In global power mode (<b>PowerSwitchingMode=0</b>), This bit is written to '1' to turn off power to all ports (clear <b>PortPowerStatus</b>). In per-port power mode, it clears <b>PortPowerStatus</b> only on ports whose <b>PortPowerControlMask</b> bit is not set. Writing a '0' has no effect.</p> |   |                                                          |   |                                                      |

## 9.6.6.21 0x0454 HcRhPortStatus Register (Default Value: 0x0000\_0100)

| Offset: 0x0454 |                                              |     |             | Register Name: HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                              |   |                                             |
|----------------|----------------------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------|---|---------------------------------------------|
| Bit            | Read/Write                                   |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                              |   |                                             |
|                | HCD                                          | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 31:21          | /                                            | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                              |   |                                             |
| 20             | R/W                                          | R/W | 0x0         | <p><b>PortResetStatusChange</b></p> <p>This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>port reset is not complete</td></tr> <tr> <td>1</td><td>port reset is complete</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                      | 0 | port reset is not complete                   | 1 | port reset is complete                      |
| 0              | port reset is not complete                   |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 1              | port reset is complete                       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 19             | R/W                                          | R/W | 0x0         | <p><b>PortOverCurrentIndicatorChange</b></p> <p>This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when Root Hub changes the <b>PortOverCurrentIndicator</b> bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortOverCurrentIndicator</b></td></tr> <tr> <td>1</td><td><b>PortOverCurrentIndicator</b> has changed</td></tr> </table>                                                                                                                                                                                                                               | 0 | no change in <b>PortOverCurrentIndicator</b> | 1 | <b>PortOverCurrentIndicator</b> has changed |
| 0              | no change in <b>PortOverCurrentIndicator</b> |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 1              | <b>PortOverCurrentIndicator</b> has changed  |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 18             | R/W                                          | R/W | 0x0         | <p><b>PortSuspendStatusChange</b></p> <p>This bit is set when the full resume sequence has been completed. This sequence includes the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. This bit is also cleared when <b>ResetStatusChange</b> is set.</p> <table border="1"> <tr> <td>0</td><td>resume is not completed</td></tr> <tr> <td>1</td><td>resume completed</td></tr> </table>                                                                                                                                                                                                                               | 0 | resume is not completed                      | 1 | resume completed                            |
| 0              | resume is not completed                      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 1              | resume completed                             |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 17             | R/W                                          | R/W | 0x0         | <p><b>PortEnableStatusChange</b></p> <p>This bit is set when hardware events cause the <b>PortEnableStatus</b> bit to be cleared. Changes from HCD writes do not set this bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table>                                                                                                                                                                                                                                                                                    | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0              | no change in <b>PortEnableStatus</b>         |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 1              | change in <b>PortEnableStatus</b>            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 16             | R/W                                          | R/W | 0x0         | <p><b>ConnectStatusChange</b></p> <p>This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared when a <b>SetPortReset</b>, <b>SetPortEnable</b>, or <b>SetPortSuspend</b> write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</p> <table border="1"> <tr> <td>0</td><td>no change in <b>PortEnableStatus</b></td></tr> <tr> <td>1</td><td>change in <b>PortEnableStatus</b></td></tr> </table> <p><b>Note:</b> If the DeviceRemovable[NDP] bit is set, this bit is set only</p> | 0 | no change in <b>PortEnableStatus</b>         | 1 | change in <b>PortEnableStatus</b>           |
| 0              | no change in <b>PortEnableStatus</b>         |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |
| 1              | change in <b>PortEnableStatus</b>            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                              |   |                                             |

| Offset: 0x0454 |                            |     |             | Register Name: HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                            |   |                           |
|----------------|----------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------|---|---------------------------|
| Bit            | Read/Write                 |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                            |   |                           |
|                | HCD                        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                            |   |                           |
|                |                            |     |             | after a Root Hub reset to inform the system that the device is attached.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                            |   |                           |
| 15:10          | /                          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                            |   |                           |
| 9              | R/W                        | R/W | 0x0         | <p>(read)<b>LowSpeedDeviceAttached</b><br/> This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When clear, a Full Speed device is attached to this port. This field is valid only when the <b>CurrentConnectStatus</b> is set.</p> <table border="1"> <tr> <td>0</td><td>full speed device attached</td></tr> <tr> <td>1</td><td>low speed device attached</td></tr> </table> <p>(write)<b>ClearPortPower</b><br/> The HCD clears the <b>PortPowerStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | full speed device attached | 1 | low speed device attached |
| 0              | full speed device attached |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                            |   |                           |
| 1              | low speed device attached  |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                            |   |                           |
| 8              | R/W                        | R/W | 0x1         | <p>(read)<b>PortPowerStatus</b><br/> This bit reflects the port's power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing <b>SetPortPower</b> or <b>SetGlobalPower</b>. HCD clears this bit by writing <b>ClearPortPower</b> or <b>ClearGlobalPower</b>. Which power control switches are enabled is determined by <b>PowerSwitchingMode</b> and <b>PortPortControlMask[NumberDownstreamPort]</b>. In global switching mode(<b>PowerSwitchingMode=0</b>), only <b>Set/ClearGlobalPower</b> controls this bit. In per-port power switching (<b>PowerSwitchingMode=1</b>), if the <b>PortPowerControlMask[NDP]</b> bit for the port is set, only <b>Set/ClearPortPower</b> commands are enabled. If the mask is not set, only <b>Set/ClearGlobalPower</b> commands are enabled. When port power is disabled, <b>CurrentConnectStatus</b>, <b>PortEnableStatus</b>, <b>PortSuspendStatus</b>, and <b>PortResetStatus</b> should be reset.</p> <table border="1"> <tr> <td>0</td><td>port power is off</td></tr> <tr> <td>1</td><td>port power is on</td></tr> </table> <p>(write)<b>SetPortPower</b><br/> The HCD writes a '1' to set the <b>PortPowerStatus</b> bit. Writing a '0' has no effect.</p> <p><b>Note:</b> This bit is always reads '1b' if power switching is not supported.</p> | 0 | port power is off          | 1 | port power is on          |
| 0              | port power is off          |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                            |   |                           |
| 1              | port power is on           |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                            |   |                           |
| 7:5            | /                          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                            |   |                           |
| 4              | R/W                        | R/W | 0x0         | (read) <b>PortResetStatus</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                            |   |                           |

| Offset: 0x0454 |                                 |     | Register Name: HcRhPortStatus |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
|----------------|---------------------------------|-----|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|---------------------------------|
| Bit            | Read/Write                      |     | Default/Hex                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                 |   |                                 |
|                | HCD                             | HC  |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
|                |                                 |     |                               | <p>When this bit is set by a write to <b>SetPortReset</b>, port reset signaling is asserted. When reset is completed, this bit is cleared when <b>PortResetStatusChange</b> is set. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared.</p> <table border="1"> <tr> <td>0</td><td>port reset signal is not active</td></tr> <tr> <td>1</td><td>port reset signal is active</td></tr> </table> <p>(write)<b>SetPortReset</b><br/>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortResetStatus</b>, but instead sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to reset a disconnected port.</p>                                                                                                        | 0 | port reset signal is not active | 1 | port reset signal is active     |
| 0              | port reset signal is not active |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 1              | port reset signal is active     |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 3              | R/W                             | R/W | 0x0                           | <p>(read)<b>PortOverCurrentIndicator</b><br/>This bit is only valid when the Root Hub is configured in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent condition exists on this port. This bit always reflects the overcurrent input signal.</p> <table border="1"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table> <p>(write)<b>ClearSuspendStatus</b><br/>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if <b>PortSuspendStatus</b> is set.</p>                                                                                                  | 0 | no overcurrent condition.       | 1 | overcurrent condition detected. |
| 0              | no overcurrent condition.       |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 1              | overcurrent condition detected. |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 2              | R/W                             | R/W | 0x0                           | <p>(read)<b>PortSuspendStatus</b><br/>This bit indicates the port is suspended or in the resume sequence. It is set by a <b>SetSuspendState</b> write and cleared when <b>PortSuspendStatusChange</b> is set at the end of the resume interval. This bit cannot be set if <b>CurrentConnectStatus</b> is cleared. This bit is also cleared when <b>PortResetStatusChange</b> is set at the end of the port reset or when the HC is placed in the USBRESUME state. If an upstream resume is in progress, it should propagate to the HC.</p> <table border="1"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table> <p>(write)<b>SetPortSuspend</b><br/>The HCD sets the <b>PortSuspendStatus</b> bit by writing a '1' to this bit. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this</p> | 0 | port is not suspended           | 1 | port is suspended               |
| 0              | port is not suspended           |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |
| 1              | port is suspended               |     |                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                                 |

| Offset: 0x0454 |                     |     |             | Register Name: HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
|----------------|---------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---|------------------|
| Bit            | Read/Write          |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                     |   |                  |
|                | HCD                 | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                     |   |                  |
|                |                     |     |             | write does not set <b>PortSuspendStatus</b> ; instead it sets <b>ConnectStatusChange</b> . This informs the driver that it attempted to suspend a disconnected port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |                     |   |                  |
| 1              | R/W                 | R/W | 0x0         | <p>(read)<b>PortEnableStatus</b></p> <p>This bit indicates whether the port is enabled or disabled. The Root Hub may clear this bit when an overcurrent condition, disconnect event, switched-off power, or operational bus error such as babble is detected. This change also causes <b>PortEnabledStatusChange</b> to be set. HCD sets this bit by writing <b>SetPortEnable</b> and clears it by writing <b>ClearPortEnable</b>. This bit cannot be set when <b>CurrentConnectStatus</b> is cleared. This bit is also set, if not already, at the completion of a port reset when <b>ResetStatusChange</b> is set or port suspend when <b>SuspendStatusChange</b> is set.</p> <table border="1"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table> <p>(write)<b>SetPortEnable</b></p> <p>The HCD sets <b>PortEnableStatus</b> by writing a '1'. Writing a '0' has no effect. If <b>CurrentConnectStatus</b> is cleared, this write does not set <b>PortEnableStatus</b>, but instead sets <b>ConnectStatusChange</b>. This informs the driver that it attempted to enable a disconnected Port.</p> | 0 | port is disabled    | 1 | port is enabled  |
| 0              | port is disabled    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                     |   |                  |
| 1              | port is enabled     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                     |   |                  |
| 0              | R/W                 | R/W | 0x0         | <p>(read)<b>CurrentConnectStatus</b></p> <p>This bit reflects the current state of the downstream port.</p> <table border="1"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table> <p>(write)<b>ClearPortEnable</b></p> <p>The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' to this bit has no effect. The CurrentConnectStatus is not affected by any write.</p> <p><b>Note:</b> This bit is always read '1' when the attached device is nonremovable (DviceRemoveable[NumberDownstreamPort]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | No device connected | 1 | Device connected |
| 0              | No device connected |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                     |   |                  |
| 1              | Device connected    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                     |   |                  |

#### 9.6.6.22 0x0800 HCI Interface Register (Default Value: 0x1000\_0000)

| Offset: 0x0800 |            |             | Register Name: USB_CTRL |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:29          | /          | /           | Reserved                |

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                        |
| 28             | R          | 1           | DMA Transfer Status Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                              |
| 27:26          | /          | /           | /                                                                                                                                                                                                                                                  |
| 25             | R/W        | 0           | OHCI count select<br>1: Simulation mode. The counters will be much shorter than real time<br>0: Normal mode. The counters will count full time                                                                                                     |
| 24:19          | /          | /           | /                                                                                                                                                                                                                                                  |
| 18             | R/W        | 0           | 1: Within 2 us of the resume-K to SEO transition<br>0: Random time value of the resume-K to SEO transition                                                                                                                                         |
| 17:13          | /          | /           | /                                                                                                                                                                                                                                                  |
| 12             | R/W        | 0           | PP2VBUS<br>1: ULPI wrapper interface will automatically set or clear DrvVbus register in ULPI PHY according to the port power status from the root hub<br>0: ULPI wrapper will ignore the difference between power status of root hub and ULPI PHY |
| 11             | R/W        | 0           | AHB Master interface INCR16 enable<br>1: Use INCR16 when appropriate<br>0: Do not use INCR16, use other enabled INCRX or unspecified length burst INCR                                                                                             |
| 10             | R/W        | 0           | AHB Master interface INCR8 enable<br>1: Use INCR8 when appropriate<br>0: Do not use INCR8, use other enabled INCRX or unspecified length burst INCR                                                                                                |
| 9              | R/W        | 0           | AHB Master interface burst type INCR4 enable<br>1: Use INCR4 when appropriate<br>0: Do not use INCR4, use other enabled INCRX or unspecified length burst INCR                                                                                     |
| 8              | R/W        | 0           | AHB Master interface INCRX align enable<br>1: Start INCRx burst only on burst x-align address<br>0: Start burst on any double word boundary<br>Note: This bit must enable if any bit of bit[11:9] is enabled                                       |
| 7:1            | /          | /           | /                                                                                                                                                                                                                                                  |
| 0              | R/W        | 0           | ULPI bypass enable<br>1: Enable UTMI interface, disable ULPI interface<br>0: Enable ULPI interface, disable UTMI interface                                                                                                                         |

### 9.6.6.23 0x0808 HCI Control 3 Register (Default Value: 0x0001\_0000)

| Offset: 0x0808 |            |             | Register Name: HCI_CTRL3                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31:17          | /          | /           | Reserved                                                                                                           |
| 16             | R/W1C      | 1           | Linestate Change Detect<br>0: Linestate change not detected<br>1: Linestate change detected<br>Write '1' to clear. |
| 15:4           | /          | /           | Reserved                                                                                                           |
| 3              | R/W        | 0           | Remote Wakeup Enable<br>1: Enable<br>0: Disable                                                                    |
| 2              | /          | /           | Reserved                                                                                                           |
| 1              | R/W        | 0           | Linestate Change Interrupt Enable<br>1: Enable<br>0: Disable                                                       |
| 0              | R/W        | 0           | Linestate Change Detect Enable<br>1: Enable<br>0: Disable                                                          |

### 9.6.6.24 0x0810 PHY Control Register (Default Value: 0x0000\_0008)

| Offset: 0x0810 |            |             | Register Name: PHY_CTRL                                        |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:17          | /          | /           | /                                                              |
| 16             | R/W        | 0           | bist_en_a                                                      |
| 15:8           | R/W        | 0           | vc_addr                                                        |
| 7              | R/W        | 0           | vc_di                                                          |
| 6:4            | /          | /           | /                                                              |
| 3              | R/W        | 0x1         | SIDDQ<br>1: Write 1 to disable phy<br>0: Write 0 to enable phy |
| 2:1            | /          | /           | /                                                              |
| 0              | R/W        | 0x0         | vc_clk                                                         |

#### 9.6.6.25 0x0824 PHY Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0824 |            |             | Register Name: PHY_STATUS |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:18          | /          | /           | /                         |
| 17             | R          | 0           | Bist_error                |
| 16             | R          | 0           | bist_done                 |
| 15:1           | /          | /           | /                         |
| 0              | R          | 0           | vc_do                     |

#### 9.6.6.26 0x0828 HCI SIE Port Disable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0828 |            |             | Register Name: USB_SPDCR                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                      |
| 16             | R/W        | 0           | SEO Status<br>This bit is set when no-se0 is detected before SOF when bit[1:0] is 10b or 11b                                                                                                                                                           |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0           | resume_sel<br>When set k-se0 transition 2 us, setting this bit to 1, which is cooperated with ss_utmi_backward_enb_i.                                                                                                                                  |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                      |
| 1:0            | R/W        | 0           | Port Disable Control<br>00: Port Disable when no-se0 detect before SOF<br>01: Port Disable when no-se0 detect before SOF<br>10: No Port Disable when no-se0 detect before SOF<br>11: Port Disable when no-se0 3 time detect before SOF during 8 frames |

## 9.7 GPIO

### 9.7.1 Overview

The general purpose input/output (GPIO) is one of the blocks controlling the chip multiplexing pins. The T113x supports 6 groups of GPIO pins. Each pin can be configured as input or output and these pins are used to generate input signals or output signals for special purposes.

The Port Controller has the following features:

- 6 groups of ports (PB, PC, PD, PE, PF, PG)
- Software control for each signal pin
- Data input (capture)/output (drive)
- Each GPIO peripheral can produce an interrupt
- Pull-up/Pull-down/no-Pull register control
- Control the direction of every signal
- 4 drive strengths in each operating mode
- Up to 72 interrupts
- Configurable interrupt edges

### 9.7.2 Block Diagram

The following figure shows the block diagram of the GPIO.

Figure 9-67 GPIO Block Diagram



The GPIO consists of the digital part (GPIO, external interface) and IO analog part (output buffer, dual pull down, pad). The digital part can select the output interface by the MUX switch; the analog part can configure pull up/down and buffer strength.

When executing GPIO read state, the GPIO reads the current level of the pin into the internal register bus.

When not executing GPIO read state, the external pin and the internal register bus are off-status, which is high-impedance.

### 9.7.3 Functional Description

#### 9.7.3.1 Multi-function Port

The T113x includes 72 multi-functional input/output port pins. There are 6 ports as listed below.

Table 9-20 Multi-function Port

| Port Name | Number of Pins | Input Driver | Output Driver | Multiplex Pins                                           | Power           |
|-----------|----------------|--------------|---------------|----------------------------------------------------------|-----------------|
| PB        | 6              | Schmitt      | CMOS          | LCD/I2S/TWI/PWM/IR/UART/PB-EINT                          | 3.3 V           |
| PC        | 6              | Schmitt      | CMOS          | SPI/SMHC/UART/BOOT/TWI/TCON/PC-EINT                      | 3.3 V           |
| PD        | 23             | Schmitt      | CMOS          | LCD/LVDS/OWA/TWI/IR/DSI/SPI-DBI/DMIC/UART/PWM/IR/PD-EINT | 3.3 V/<br>1.8 V |

| Port Name | Number of Pins | Input Driver | Output Driver | Multiplex Pins                                                     | Power                     |
|-----------|----------------|--------------|---------------|--------------------------------------------------------------------|---------------------------|
| PE        | 14             | Schmitt      | CMOS          | NCSI/TWI/UART/PWM/LCD/OWA/LEDC/IR/JTAG/EMAC/PE-EINT                | 3.3 V/<br>2.8 V/<br>1.8 V |
| PF        | 7              | Schmitt      | CMOS          | SMHC/JTAG/UART/OWA/TWI/IR/I2S/PWM/                                 | 3.3 V                     |
| PG        | 16             | Schmitt      | CMOS          | PF-EINT<br>SMHC/UART/PWM/I2S/TWI/EMAC/OWA/IR/TCON/LEDC/SPI/PG-EINT | 3.3 V/<br>1.8 V           |

### 9.7.3.2 GPIO Multiplex Function

Table 9-21 to Table 9-26 show the multiplex function pins of the T113x.


**NOTE**

For each GPIO, Function0 is input function; Function1 is output function; Function9 to Function13 are reserved.

**Table 9-21 PB Multiplex Function**

| GPIO Port | Function 2 | Function 3 | Function 4 | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------|------------|------------|------------|------------|-------------|
| PB2       | LCD0-D0    | I2S2-DOUT2 | TWI0-SDA   | I2S2-DIN2  | LCD0-D18   | UART4-TX   | CAN0_TX0   | PB-EINT2    |
| PB3       | LCD0-D1    | I2S2-DOUT1 | TWI0-SCK   | I2S2-DIN0  | LCD0-D19   | UART4-RX   | CAN0_RX0   | PB-EINT3    |
| PB4       | LCD0-D8    | I2S2-DOUT0 | TWI1-SCK   | I2S2-DIN1  | LCD0-D20   | UART5-TX   | CAN1_TX0   | PB-EINT4    |
| PB5       | LCD0-D9    | I2S2-BCLK  | TWI1-SDA   | PWM0       | LCD0-D21   | UART5-RX   | CAN1_RX0   | PB-EINT5    |
| PB6       | LCD0-D16   | I2S2-LRCK  | TWI3-SCK   | PWM1       | LCD0-D22   | UART3-TX   | CPUBIST0   | PB-EINT6    |
| PB7       | LCD0-D17   | I2S2-MCLK  | TWI3-SDA   | IR-RX      | LCD0-D23   | UART3-RX   | CPUBIST1   | PB-EINT7    |

**Table 9-22 PC Multiplex Function**

| GPIO Port | Function 2 | Function 3 | Function 4 | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------|------------|------------|------------|------------|-------------|
| PC2       | SPI0-CLK   | SDC2-CLK   |            |            |            |            |            | PC-EINT2    |
| PC3       | SPI0-CS0   | SDC2-CMD   |            |            |            |            |            | PC-EINT3    |
| PC4       | SPI0-MOSI  | SDC2-D2    | BOOT-SEL0  |            |            |            |            | PC-EINT4    |
| PC5       | SPI0-MISO  | SDC2-D1    | BOOT-SEL1  |            |            |            |            | PC-EINT5    |
| PC6       | SPI0-WP    | SDC2-D0    | UART3-TX   | TWI3-SCK   | DBG-CLK    |            |            | PC-EINT6    |
| PC7       | SPI0-HOLD  | SDC2-D3    | UART3-RX   | TWI3-SDA   | TCON-TRIG  |            |            | PC-EINT7    |

**Table 9-23 PD Multiplex Function**

| GPIO Port | Function 2 | Function 3 | Function 4            | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|-----------------------|------------|------------|------------|------------|-------------|
| PD0       | LCD0-D2    | LVDS0-V0P  | DSI-D0P               | TWI0-SCK   |            |            |            | PD-EINT0    |
| PD1       | LCD0-D3    | LVDS0-V0N  | DSI-D0N               | UART2-TX   |            |            |            | PD-EINT1    |
| PD2       | LCD0-D4    | LVDS0-V1P  | DSI-D1P               | UART2-RX   |            |            |            | PD-EINT2    |
| PD3       | LCD0-D5    | LVDS0-V1N  | DSI-D1N               | UART2-RTS  |            |            |            | PD-EINT3    |
| PD4       | LCD0-D6    | LVDS0-V2P  | DSI-CKP               | UART2-CTS  |            |            |            | PD-EINT4    |
| PD5       | LCD0-D7    | LVDS0-V2N  | DSI-CKN               | UART5-TX   |            |            |            | PD-EINT5    |
| PD6       | LCD0-D10   | LVDS0-CKP  | DSI-D2P               | UART5-RX   |            |            |            | PD-EINT6    |
| PD7       | LCD0-D11   | LVDS0-CKN  | DSI-D2N               | UART4-TX   |            |            |            | PD-EINT7    |
| PD8       | LCD0-D12   | LVDS0-V3P  | DSI-D3P               | UART4-RX   |            |            |            | PD-EINT8    |
| PD9       | LCD0-D13   | LVDS0-V3N  | DSI-D3N               | PWM6       |            |            |            | PD-EINT9    |
| PD10      | LCD0-D14   | LVDS1-V0P  | SPI1-CS/DBI-CSX       | UART3-TX   |            |            |            | PD-EINT10   |
| PD11      | LCD0-D15   | LVDS1-V0N  | SPI1-CLK/<br>DBI-SCLK | UART3-RX   |            |            |            | PD-EINT11   |
| PD12      | LCD0-D18   | LVDS1-V1P  | SPI1-MOSI/<br>DBI-SDO | TWI0-SDA   |            |            |            | PD-EINT12   |

| GPIO Port | Function 2 | Function 3 | Function 4                               | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------------------------------------|------------|------------|------------|------------|-------------|
| PD13      | LCD0-D19   | LVDS1-V1N  | SPI1-MISO/<br>DBI-SDI/DBI-TE/<br>DBI-DCX | UART3-RTS  |            |            |            | PD-EINT13   |
| PD14      | LCD0-D20   | LVDS1-V2P  | SPI1-HOLD/<br>DBI-DCX/<br>DBI-WRX        | UART3-CTS  |            |            |            | PD-EINT14   |
| PD15      | LCD0-D21   | LVDS1-V2N  | SPI1-WP/DBI-TE                           | IR-RX      |            |            |            | PD-EINT15   |
| PD16      | LCD0-D22   | LVDS1-CKP  | DMIC-DATA3                               | PWM0       |            |            |            | PD-EINT16   |
| PD17      | LCD0-D23   | LVDS1-CKN  | DMIC-DATA2                               | PWM1       |            |            |            | PD-EINT17   |
| PD18      | LCD0-CLK   | LVDS1-V3P  | DMIC-DATA1                               | PWM2       |            |            |            | PD-EINT18   |
| PD19      | LCD0-DE    | LVDS1-V3N  | DMIC-DATA0                               | PWM3       |            |            |            | PD-EINT19   |
| PD20      | LCD0-HSYNC | TWI2-SCK   | DMIC-CLK                                 | PWM4       |            |            |            | PD-EINT20   |
| PD21      | LCD0-VSYNC | TWI2-SDA   | UART1-TX                                 | PWM5       |            |            |            | PD-EINT21   |
| PD22      | OWA-OUT    | IR-RX      | UART1-RX                                 | PWM7       |            |            |            | PD-EINT22   |

Table 9-24 PE Multiplex Function

| GPIO Port | Function 2  | Function 3  | Function 4 | Function 5  | Function 6 | Function 7 | Function 8                   | Function 14 |
|-----------|-------------|-------------|------------|-------------|------------|------------|------------------------------|-------------|
| PE0       | NCSI0-HSYNC | UART2-RTS   | TWI1-SCK   | LCD0-HSYNC  |            |            | RGMII-RXCTRL/<br>RMII-CRS-DV | PE-EINT0    |
| PE1       | NCSI0-VSYNC | UART2-CTS   | TWI1-SDA   | LCD0-VSYNC  |            |            | RGMII-RXD0/<br>RMII-RXD0     | PE-EINT1    |
| PE2       | NCSI0-PCLK  | UART2-TX    | TWI0-SCK   | CLK-FANOUT0 | UART0-TX   |            | RGMII-RXD1/<br>RMII-RXD1     | PE-EINT2    |
| PE3       | NCSI0-MCLK  | UART2-RX    | TWI0-SDA   | CLK-FANOUT1 | UART0-RX   |            | RGMII-TXCK/<br>RMII-TXCK     | PE-EINT3    |
| PE4       | NCSI0-D0    | UART4-TX    | TWI2-SCK   | CLK-FANOUT2 | D-JTAG-MS  |            | RGMII-TXD0/<br>RMII-TXD0     | PE-EINT4    |
| PE5       | NCSI0-D1    | UART4-RX    | TWI2-SDA   | LEDC-DO     | D-JTAG-DI  |            | RGMII-TXD1/<br>RMII-TXD1     | PE-EINT5    |
| PE6       | NCSI0-D2    | UART5-TX    | TWI3-SCK   |             | D-JTAG-DO  |            | RGMII-TXCTRL/<br>RMII-TXEN   | PE-EINT6    |
| PE7       | NCSI0-D3    | UART5-RX    | TWI3-SDA   | OWA-OUT     | D-JTAG-CK  |            | RGMII-CLKIN/<br>RMII-RXER    | PE-EINT7    |
| PE8       | NCSI0-D4    | UART1-RTS   | PWM2       | UART3-TX    | JTAG-MS    |            | MDC                          | PE-EINT8    |
| PE9       | NCSI0-D5    | UART1-CTS   | PWM3       | UART3-RX    | JTAG-DI    |            | MDIO                         | PE-EINT9    |
| PE10      | NCSI0-D6    | UART1-TX    | PWM4       | IR-RX       | JTAG-DO    |            | EPHY-25M                     | PE-EINT10   |
| PE11      | NCSI0-D7    | UART1-RX    |            |             | JTAG-CK    |            | RGMII-TXD2                   | PE-EINT11   |
| PE12      | TWI2-SCK    | NCSI0-FIELD |            |             |            |            | RGMII-TXD3                   | PE-EINT12   |
| PE13      | TWI2-SDA    | PWM5        |            |             | DMIC-DATA3 |            | RGMII-RXD2                   | PE-EINT13   |

Table 9-25 PF Multiplex Function

| GPIO Port | Function 2 | Function 3 | Function 4 | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------|------------|------------|------------|------------|-------------|
| PF0       | SDC0-D1    | JTAG-MS    |            | I2S2-DOUT1 | I2S2-DIN0  |            |            | PF-EINT0    |
| PF1       | SDC0-D0    | JTAG-DI    |            | I2S2-DOUT0 | I2S2-DIN1  |            |            | PF-EINT1    |
| PF2       | SDC0-CLK   | UART0-TX   | TWI0-SCK   |            |            |            |            | PF-EINT2    |
| PF3       | SDC0-CMD   | JTAG-DO    |            | I2S2-BCLK  |            |            |            | PF-EINT3    |
| PF4       | SDC0-D3    | UART0-RX   | TWI0-SDA   | PWM6       | IR-TX      |            |            | PF-EINT4    |

| GPIO Port | Function 2 | Function 3 | Function 4 | Function 5 | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------|------------|------------|------------|------------|-------------|
| PF5       | SDC0-D2    | JTAG-CK    |            | I2S2-LRCK  |            |            |            | PF-EINT5    |
| PF6       |            | OWA-OUT    | IR-RX      | I2S2-MCLK  | PWM5       |            |            | PF-EINT6    |

Table 9-26 PG Multiplex Function

| GPIO Port | Function 2 | Function 3 | Function 4                   | Function 5  | Function 6 | Function 7 | Function 8 | Function 14 |
|-----------|------------|------------|------------------------------|-------------|------------|------------|------------|-------------|
| PG0       | SDC1-CLK   | UART3-TX   | RGMII-RXCTRL/<br>RMII-CRS-DV | PWM7        |            |            |            | PG-EINT0    |
| PG1       | SDC1-CMD   | UART3-RX   | RGMII-RXD0/<br>RMII-RXD0     | PWM6        |            |            |            | PG-EINT1    |
| PG2       | SDC1-D0    | UART3-RTS  | RGMII-RXD1/<br>RMII-RXD1     | UART4-TX    |            |            |            | PG-EINT2    |
| PG3       | SDC1-D1    | UART3-CTS  | RGMII-TXCK/<br>RMII-TXCK     | UART4-RX    |            |            |            | PG-EINT3    |
| PG4       | SDC1-D2    | UART5-TX   | RGMII-TXD0/<br>RMII-TXD0     | PWM5        |            |            |            | PG-EINT4    |
| PG5       | SDC1-D3    | UART5-RX   | RGMII-TXD1/<br>RMII-TXD1     | PWM4        |            |            |            | PG-EINT5    |
| PG6       | UART1-TX   | TWI2-SCK   | RGMII-TXD2                   | PWM1        |            |            |            | PG-EINT6    |
| PG7       | UART1-RX   | TWI2-SDA   | RGMII-TXD3                   |             |            |            |            | PG-EINT7    |
| PG8       | UART1-RTS  | TWI1-SCK   | RGMII-RXD2                   | UART3-TX    |            |            |            | PG-EINT8    |
| PG9       | UART1-CTS  | TWI1-SDA   | RGMII-RXD3                   | UART3-RX    |            |            |            | PG-EINT9    |
| PG10      | PWM3       | TWI3-SCK   | RGMII-RXCK                   | CLK-FANOUT0 | IR-RX      |            |            | PG-EINT10   |
| PG11      | I2S1-MCLK  | TWI3-SDA   | EPHY-25M                     | CLK-FANOUT1 | TCON-TRIG  |            |            | PG-EINT11   |
| PG12      | I2S1-LRCK  | TWI0-SCK   | RGMII-TXCTRL/<br>RMII-TXEN   | CLK-FANOUT2 | PWM0       | UART1-TX   |            | PG-EINT12   |
| PG13      | I2S1-BCLK  | TWI0-SDA   | RGMII-CLKIN/<br>RMII-RXER    | PWM2        | LEDG-DO    | UART1-RX   |            | PG-EINT13   |
| PG14      | I2S1-DIN0  | TWI2-SCK   | MDC                          | I2S1-DOUT1  | SPI0-WP    | UART1-RTS  |            | PG-EINT14   |
| PG15      | I2S1-DOUT0 | TWI2-SDA   | MDIO                         | I2S1-DIN1   | SPI0-HOLD  | UART1-CTS  |            | PG-EINT15   |

### 9.7.3.3 Port Function

The Port Controller supports 6 GPIOs, every GPIO can configure as Input, Output, Function Peripheral, IO disable or Interrupt function. The configuration instruction of every function is as follows.

**Table 9-27 Port Function**

|           | Function                 | Buffer Strength | Pull Up | Pull Down |
|-----------|--------------------------|-----------------|---------|-----------|
| Input     | GPIO/Multiplexing Input  | /               | X       | X         |
| Output    | GPIO/Multiplexing Output | Y               | X       | X         |
| Disable   | Pull Up                  | /               | Y       | N         |
|           | Pull Down                | /               | N       | Y         |
| Interrupt | Trigger                  | /               | X       | X         |

/: non-configure, configuration is invalid

Y: configure

X: Select configuration according to the actual situation

N: Forbid to configure

### 9.7.3.4 Pull Up/Down and High-Impedance Logic

Each IO pin can configure the internal pull-up/down function or high-impedance.

**Figure 9-68 Pull up/down Logic**



**High-impedance**, the output is float state, all buffer is off, the level is decided by external high/low level. When high-impedance, the software configures the switch on Rpu and Rpd as off, and the multiplexing function of IO is set as IO disable or input by software.

**Pull-up**, an uncertain signal is pulled high by resistance, the resistance has a current-limiting function. When pulling up, the switch on Rpu is conducted by software configuration, the IO is pulled up to VCC by Rpu.

**Pull-down**, an uncertain signal is pulled low by a resistance. When pulling down, the switch on Rpd is conducted by software configuration, the IO is pulled down to GND by Rpd.

The pull-up/down of each IO is weak pull-up/down.

The setting of pull-down, pull-up, high-impedance is decided by the external circuit.

#### 9.7.3.5 Buffer Strength

Each IO can be set as different buffer strength. The IO buffer diagram is as follows.

Figure 9-69 IO Buffer Strength Diagram



When output high level, the n0, n1, n2, n3 of NMOS is off, the p0, p1, p2, p3 of PMOS is on. When the buffer strength is set to 0 (buffer strength is weakest), only the p0 is on, the output impedance is maximum, the impedance value is  $r_o$ . When the buffer strength is set to 1, only the p0 and p1 is on, the output impedance is equivalent to two  $r_o$  in parallel, the impedance value is  $r_o/2$ . When the buffer strength is 2, only the p0, p1, and p2 is on, the output impedance is equivalent to three  $r_o$  in parallel, the impedance value is  $r_o/3$ . When buffer strength is 3, the p0, p1, p2, and p3 is on, the output impedance is equivalent to four  $r_o$  in parallel, the impedance value is  $r_o/4$ .

When output low level, the p0, p1, p2, p3 of PMOS is off, the n0, n1, n2, n3 of NMOS is on. When the buffer strength is set to 0 (buffer strength is weakest), only the n0 is on, the output impedance is maximum, the

impedance value is  $r_0$ . When the buffer strength is set to 1, only the n0 and n1 is on, the output impedance is equivalent to two  $r_0$  in parallel, the impedance value is  $r_0/2$ . When the buffer strength is 2, only the n0, n1, and n2 is on, the output impedance is equivalent to three  $r_0$  in parallel, the impedance value is  $r_0/3$ . When the buffer strength is 3, the n0, n1, n2, and n3 is on, the output impedance is equivalent to four  $r_0$  in parallel, the impedance value is  $r_0/4$ .

When GPIO is set to input or interrupt function, between the output driver circuit and the port is unconnected, the driver configuration is invalid.

**NOTE**

The typical value of  $r_0$  is  $180\Omega$ .

### 9.7.3.6 Interrupt

Each group IO has an independent interrupt number. The IO within-group uses one interrupt number when one IO generates interrupt, the GPIO pins sent interrupt request to interrupt module. External Interrupt Status Register is used to query which IO generates interrupt.

The interrupt trigger of GPIO supports the following trigger types.

- Positive Edge: When a low level changes to a high level, the interrupt will generate. No matter how long a high level keeps, the interrupt generates only once.
- Negative Edge: When a high level changes to a low level, the interrupt will generate. No matter how long a low level keeps, the interrupt generates only once.
- High Level: Just keep a high level and the interrupt will always generate.
- Low Level: Just keep a low level and the interrupt will always generate.
- Double Edge: Positive and negative edge.

External Interrupt Configure Register is used to configure the trigger type.

The GPIO interrupt supports hardware debounce function by setting External Interrupt Debounce Register. Sample trigger signal using a lower sample clock, to reach the debounce effect because the dither frequency of the signal is higher than the sample frequency.

Set the sample clock source by PIO\_INT\_CLK\_SELECT and the prescale factor by DEB\_CLK\_PRE\_SCALE.

### 9.7.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPIO        | 0x02000000   |

| Register Name | Offset | Description                 |
|---------------|--------|-----------------------------|
| PB_CFG0       | 0x0030 | PB Configure Register 0     |
| PB_CFG1       | 0x0034 | PB Configure Register 1     |
| PB_DAT        | 0x0040 | PB Data Register            |
| PB_DRV0       | 0x0044 | PB Multi_Driving Register 0 |
| PB_DRV1       | 0x0048 | PB Multi_Driving Register 1 |
| PB_PULL0      | 0x0054 | PB Pull Register 0          |
| PC_CFG0       | 0x0060 | PC Configure Register 0     |
| PC_DAT        | 0x0070 | PC Data Register            |
| PC_DRV0       | 0x0074 | PC Multi_Driving Register 0 |
| PC_PULL0      | 0x0084 | PC Pull Register 0          |
| PD_CFG0       | 0x0090 | PD Configure Register 0     |
| PD_CFG1       | 0x0094 | PD Configure Register 1     |
| PD_CFG2       | 0x0098 | PD Configure Register 2     |
| PD_DAT        | 0x00A0 | PD Data Register            |
| PD_DRV0       | 0x00A4 | PD Multi_Driving Register 0 |
| PD_DRV1       | 0x00A8 | PD Multi_Driving Register 1 |
| PD_DRV2       | 0x00AC | PD Multi_Driving Register 2 |
| PD_PULL0      | 0x00B4 | PD Pull Register 0          |
| PD_PULL1      | 0x00B8 | PD Pull Register 1          |
| PE_CFG0       | 0x00C0 | PE Configure Register 0     |
| PE_CFG1       | 0x00C4 | PE Configure Register 1     |
| PE_DAT        | 0x00D0 | PE Data Register            |
| PE_DRV0       | 0x00D4 | PE Multi_Driving Register 0 |
| PE_DRV1       | 0x00D8 | PE Multi_Driving Register 1 |
| PE_PULL0      | 0x00E4 | PE Pull Register 0          |
| PF_CFG0       | 0x00F0 | PF Configure Register 0     |
| PF_DAT        | 0x0100 | PF Data Register            |
| PF_DRV0       | 0x0104 | PF Multi_Driving Register 0 |
| PF_PULL0      | 0x0114 | PF Pull Register 0          |
| PG_CFG0       | 0x0120 | PG Configure Register 0     |
| PG_CFG1       | 0x0124 | PG Configure Register 1     |
| PG_DAT        | 0x0130 | PG Data Register            |

| Register Name   | Offset | Description                                              |
|-----------------|--------|----------------------------------------------------------|
| PG_DRV0         | 0x0134 | PG Multi_Driving Register 0                              |
| PG_DRV1         | 0x0138 | PG Multi_Driving Register 1                              |
| PG_DRV3         | 0x0140 | PG Multi_Driving Register 3                              |
| PG_PULL0        | 0x0144 | PG Pull Register 0                                       |
| PB_EINT_CFG0    | 0x0220 | PB External Interrupt Configure Register 0               |
| PB_EINT_CTL     | 0x0230 | PB External Interrupt Control Register                   |
| PB_EINT_STATUS  | 0x0234 | PB External Interrupt Status Register                    |
| PB_EINT_DEB     | 0x0238 | PB External Interrupt Debounce Register                  |
| PC_EINT_CFG0    | 0x0240 | PC External Interrupt Configure Register 0               |
| PC_EINT_CTL     | 0x0250 | PC External Interrupt Control Register                   |
| PC_EINT_STATUS  | 0x0254 | PC External Interrupt Status Register                    |
| PC_EINT_DEB     | 0x0258 | PC External Interrupt Debounce Register                  |
| PD_EINT_CFG0    | 0x0260 | PD External Interrupt Configure Register 0               |
| PD_EINT_CFG1    | 0x0264 | PD External Interrupt Configure Register 1               |
| PD_EINT_CFG2    | 0x0268 | PD External Interrupt Configure Register 2               |
| PD_EINT_CTL     | 0x0270 | PD External Interrupt Control Register                   |
| PD_EINT_STATUS  | 0x0274 | PD External Interrupt Status Register                    |
| PD_EINT_DEB     | 0x0278 | PD External Interrupt Debounce Register                  |
| PE_EINT_CFG0    | 0x0280 | PE External Interrupt Configure Register 0               |
| PE_EINT_CFG1    | 0x0284 | PE External Interrupt Configure Register 1               |
| PE_EINT_CTL     | 0x0290 | PE External Interrupt Control Register                   |
| PE_EINT_STATUS  | 0x0294 | PE External Interrupt Status Register                    |
| PE_EINT_DEB     | 0x0298 | PE External Interrupt Debounce Register                  |
| PF_EINT_CFG0    | 0x02A0 | PF External Interrupt Configure Register 0               |
| PF_EINT_CTL     | 0x02B0 | PF External Interrupt Control Register                   |
| PF_EINT_STATUS  | 0x02B4 | PF External Interrupt Status Register                    |
| PF_EINT_DEB     | 0x02B8 | PF External Interrupt Debounce Register                  |
| PG_EINT_CFG0    | 0x02C0 | PG External Interrupt Configure Register 0               |
| PG_EINT_CFG1    | 0x02C4 | PG External Interrupt Configure Register 1               |
| PG_EINT_CTL     | 0x02D0 | PG External Interrupt Control Register                   |
| PG_EINT_STATUS  | 0x02D4 | PG External Interrupt Status Register                    |
| PG_EINT_DEB     | 0x02D8 | PG External Interrupt Debounce Register                  |
| PIO_POW_MOD_SEL | 0x0340 | PIO Group Withstand Voltage Mode Select Register         |
| PIO_POW_MS_CTL  | 0x0344 | PIO Group Withstand Voltage Mode Select Control Register |
| PIO_POW_VAL     | 0x0348 | PIO Group Power Value Register                           |

| Register Name       | Offset | Description                                     |
|---------------------|--------|-------------------------------------------------|
| PIO_POW_VOL_SEL_CTL | 0x0350 | PIO Group Power Voltage Select Control Register |

### 9.7.5 Register Description

#### 9.7.5.1 0x0030 PB Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0030 |            |             | Register Name: PB_CFG0                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
| 31:28          | R/W        | 0xF         | PB7_SELECT<br>PB7 Select<br>0000:Input 0001:Output<br>0010:LCD0-D17 0011:I2S2-MCLK<br>0100:TWI3-SDA 0101:IR-RX<br>0110:LCD0-D23 0111:UART3-RX<br>1000:CPUBIST1 1001:Reserved<br>1110:PB-EINT7 1111:IO Disable |
| 27:24          | R/W        | 0xF         | PB6_SELECT<br>PB6 Select<br>0000:Input 0001:Output<br>0010:LCD0-D16 0011:I2S2-LRCK<br>0100:TWI3-SCK 0101:PWM1<br>0110:LCD0-D22 0111:UART3-TX<br>1000:CPUBIST0 1001:Reserved<br>1110:PB-EINT6 1111:IO Disable  |
| 23:20          | R/W        | 0xF         | PB5_SELECT<br>PB5 Select<br>0000:Input 0001:Output<br>0010:LCD0-D9 0011:I2S2-BCLK<br>0100:TWI1-SDA 0101:PWM0<br>0110:LCD0-D21 0111:UART5-RX<br>1000:Reserved 1001:Reserved<br>1110:PB-EINT5 1111:IO Disable   |

| Offset: 0x0030 |            |             | Register Name: PB_CFG0                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 19:16          | R/W        | 0xF         | PB4_SELECT<br>PB4 Select<br>0000:Input 0001:Output<br>0010:LCD0-D8 0011:I2S2-DOUT0<br>0100:TWI1-SCK 0101:I2S2-DIN1<br>0110:LCD0-D20 0111:UART5-TX<br>1000:Reserved 1001:Reserved<br>1110:PB-EINT4 1111:IO Disable |
| 15:12          | R/W        | 0xF         | PB3_SELECT<br>PB3 Select<br>0000:Input 0001:Output<br>0010:LCD0-D1 0011:I2S2-DOUT1<br>0100:TWI0-SCK 0101:I2S2-DIN0<br>0110:LCD0-D19 0111:UART4-RX<br>1000:Reserved 1001:Reserved<br>1110:PB-EINT3 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PB2_SELECT<br>PB2 Select<br>0000:Input 0001:Output<br>0010:LCD0-D0 0011:I2S2-DOUT2<br>0100:TWI0-SDA 0101:I2S2-DIN2<br>0110:LCD0-D18 0111:UART4-TX<br>1000:Reserved 1001:Reserved<br>1110:PB-EINT2 1111:IO Disable |
| 7:4            | R/W        | 0xF         | Reserved                                                                                                                                                                                                          |
| 3:0            | R/W        | 0xF         | Reserved                                                                                                                                                                                                          |

### 9.7.5.2 0x0034 PB Configure Register 1 (Default Value: 0x000F\_FFFF)

| Offset: 0x0034 |            |             | Register Name: PB_CFG1 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:20          | /          | /           | /                      |
| 19:16          | R/W        | 0xF         | Reserved               |
| 15:12          | R/W        | 0xF         | Reserved               |
| 11:8           | R/W        | 0xF         | Reserved               |

| Offset: 0x0034 |            |             | Register Name: PB_CFG1 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 7:4            | R/W        | 0xF         | Reserved               |
| 3:0            | R/W        | 0xF         | Reserved               |

#### 9.7.5.3 0x0040 PB Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: PB_DAT                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 7:0            | R/W        | 0x0         | PB_DAT<br>If the port is configured as the input function, the corresponding bit is the pin state. If the port is configured as the output function, the pin state is the same as the corresponding bit. The read bit value is the value set up by software. If the port is configured as a functional pin, the undefined value will be read. |

#### 9.7.5.4 0x0044 PB Multi\_Driving Register 0 (Default Value: 0x1111\_1111)

| Offset: 0x0044 |            |             | Register Name: PB_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:30          | /          | /           | /                                                                                         |
| 29:28          | R/W        | 0x1         | PB7_DRV<br>PB7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                         |
| 25:24          | R/W        | 0x1         | PB6_DRV<br>PB6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                         |
| 21:20          | R/W        | 0x1         | PB5_DRV<br>PB5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

| Offset: 0x0044 |            |             | Register Name: PB_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 19:18          | /          | /           | /                                                                                         |
| 17:16          | R/W        | 0x1         | PB4_DRV<br>PB4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                         |
| 13:12          | R/W        | 0x1         | PB3_DRV<br>PB3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                         |
| 9:8            | R/W        | 0x1         | PB2_DRV<br>PB2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                         |
| 5:4            | R/W        | 0x1         | Reserved                                                                                  |
| 3:2            | /          | /           | /                                                                                         |
| 1:0            | R/W        | 0x1         | Reserved                                                                                  |

#### 9.7.5.5 0x0048 PB Multi\_Driving Register 1 (Default Value: 0x0001\_1111)

| Offset: 0x0048 |            |             | Register Name: PB_DRV1 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:18          | /          | /           | /                      |
| 17:16          | R/W        | 0x1         | Reserved               |
| 15:14          | /          | /           | /                      |
| 13:12          | R/W        | 0x1         | Reserved               |
| 11:10          | /          | /           | /                      |
| 9:8            | R/W        | 0x1         | Reserved               |
| 7:6            | /          | /           | /                      |
| 5:4            | R/W        | 0x1         | Reserved               |
| 3:2            | /          | /           | /                      |
| 1:0            | R/W        | 0x1         | Reserved               |

## 9.7.5.6 0x0054 PB Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: PB_PULL0                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                              |
| 15:14          | R/W        | 0x0         | PB7_PULL<br>PB7 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 13:12          | R/W        | 0x0         | PB6_PULL<br>PB6 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 11:10          | R/W        | 0x0         | PB5_PULL<br>PB5 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 9:8            | R/W        | 0x0         | PB4_PULL<br>PB4 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 7:6            | R/W        | 0x0         | PB3_PULL<br>PB3 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 5:4            | R/W        | 0x0         | PB2_PULL<br>PB2 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 3:2            | R/W        | 0x0         | Reserved                                                                                                                       |
| 1:0            | R/W        | 0x0         | Reserved                                                                                                                       |

## 9.7.5.7 0x0060 PC Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0060 |            |             | Register Name: PC_CFG0                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 31:28          | R/W        | 0xF         | PC7_SELECT<br>PC7 Select<br>0000:Input 0001:Output<br>0010:SPI0-HOLD 0011:SDC2-D3<br>0100:UART3-RX 0101:TWI3-SDA<br>0110:TCON-TRIG 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT7 1111:IO Disable  |
| 27:24          | R/W        | 0xF         | PC6_SELECT<br>PC6 Select<br>0000:Input 0001:Output<br>0010:SPI0-WP 0011:SDC2-D0<br>0100:UART3-TX 0101:TWI3-SCK<br>0110:DBG-CLK 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT6 1111:IO Disable      |
| 23:20          | R/W        | 0xF         | PC5_SELECT<br>PC5 Select<br>0000:Input 0001:Output<br>0010:SPI0-MISO 0011:SDC2-D1<br>0100:BOOT-SEL1 0101:Reserved<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT5 1111:IO Disable  |
| 19:16          | R/W        | 0xF         | PC4_SELECT<br>PC4 Select.<br>0000:Input 0001:Output<br>0010:SPI0-MOSI 0011:SDC2-D2<br>0100:BOOT-SEL0 0101:Reserved<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT4 1111:IO Disable |

| Offset: 0x0060 |            |             | Register Name: PC_CFG0                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 15:12          | R/W        | 0xF         | PC3_SELECT<br>PC3 Select<br>0000:Input 0001:Output<br>0010:SPI0-CS0 0011:SDC2-CMD<br>0100:Reserved 0101:Reserved<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT3 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PC2_SELECT<br>PC2 Select<br>0000:Input 0001:Output<br>0010:SPI0-CLK 0011:SDC2-CLK<br>0100:Reserved 0101:Reserved<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PC-EINT2 1111:IO Disable |
| 7:4            | R/W        | 0xF         | Reserved                                                                                                                                                                                                        |
| 3:0            | R/W        | 0xF         | Reserved                                                                                                                                                                                                        |

#### 9.7.5.8 0x0070 PC Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0070 |            |             | Register Name: PC_DAT                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 7:0            | R/W        | 0x0         | PC_DAT<br>If the port is configured as the input function, the corresponding bit is the pin state. If the port is configured as the output function, the pin state is the same as the corresponding bit. The read bit value is the value set up by software. If the port is configured as a functional pin, the undefined value will be read. |

## 9.7.5.9 0x0074 PC Multi\_Driving Register 0 (Default Value: 0x1111\_1111)

| Offset: 0x0074 |            |             | Register Name: PC_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:30          | /          | /           | /                                                                                         |
| 29:28          | R/W        | 0x1         | PC7_DRV<br>PC7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                         |
| 25:24          | R/W        | 0x1         | PC6_DRV<br>PC6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                         |
| 21:20          | R/W        | 0x1         | PC5_DRV<br>PC5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                         |
| 17:16          | R/W        | 0x1         | PC4_DRV<br>PC4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                         |
| 13:12          | R/W        | 0x1         | PC3_DRV<br>PC3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                         |
| 9:8            | R/W        | 0x1         | PC2_DRV<br>PC2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                         |
| 5:4            | R/W        | 0x1         | Reserved                                                                                  |
| 3:2            | /          | /           | /                                                                                         |
| 1:0            | R/W        | 0x1         | Reserved                                                                                  |

## 9.7.5.10 0x0084 PC Pull Register 0 (Default Value: 0x0000\_0540)

| Offset: 0x0084 |            |             | Register Name: PC_PULL0                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:16          | /          | /           | /                                                                                                         |
| 15:14          | R/W        | 0x0         | PC7_PULL<br>PC7 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 13:12          | R/W        | 0x0         | PC6_PULL<br>PC6 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 11:10          | R/W        | 0x1         | PC5_PULL<br>PC5 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 9:8            | R/W        | 0x1         | PC4_PULL<br>PC4 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 7:6            | R/W        | 0x1         | PC3_PULL<br>PC3 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 5:4            | R/W        | 0x0         | PC2_PULL<br>PC2 Pull_up/down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 3:2            | R/W        | 0x0         | Reserved                                                                                                  |
| 1:0            | R/W        | 0x0         | Reserved                                                                                                  |

**9.7.5.11 0x0090 PD Configure Register 0 (Default Value: 0xFFFF\_FFFF)**

| Offset: 0x0090 |            |             | Register Name: PD_CFG0                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:28          | R/W        | 0xF         | PD7_SELECT<br>PD7 Select<br>0000:Input 0001:Output<br>0010:LCD0-D11 0011:LVDS0-CKN<br>0100:DSI-D2N 0101:UART4-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT7 1111:IO Disable |
| 27:24          | R/W        | 0xF         | PD6_SELECT<br>PD6 Select<br>0000:Input 0001:Output<br>0010:LCD0-D10 0011:LVDS0-CKP<br>0100:DSI-D2P 0101:UART5-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT6 1111:IO Disable |
| 23:20          | R/W        | 0xF         | PD5_SELECT<br>PD5 Select<br>0000:Input 0001:Output<br>0010:LCD0-D7 0011:LVDS0-V2N<br>0100:DSI-CKN 0101:UART5-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT5 1111:IO Disable  |
| 19:16          | R/W        | 0xF         | PD4_SELECT<br>PD4 Select<br>0000:Input 0001:Output<br>0010:LCD0-D6 0011:LVDS0-V2P<br>0100:DSI-CKP 0101:UART2-CTS<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT4 1111:IO Disable |

| Offset: 0x0090 |            |             | Register Name: PD_CFG0                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 15:12          | R/W        | 0xF         | PD3_SELECT<br>PD3 Select<br>0000:Input 0001:Output<br>0010:LCD0-D5 0011:LVDS0-V1N<br>0100:DSI-D1N 0101:UART2-RTS<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT3 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PD2_SELECT<br>PD2 Select<br>0000:Input 0001:Output<br>0010:LCD0-D4 0011:LVDS0-V1P<br>0100:DSI-D1P 0101:UART2-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT2 1111:IO Disable  |
| 7:4            | R/W        | 0xF         | PD1_SELECT<br>PD1 Select<br>0000:Input 0001:Output<br>0010:LCD0-D3 0011:LVDS0-V0N<br>0100:DSI-D0N 0101:UART2-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT1 1111:IO Disable  |
| 3:0            | R/W        | 0xF         | PDO_SELECT<br>PDO Select<br>0000:Input 0001:Output<br>0010:LCD0-D2 0011:LVDS0-V0P<br>0100:DSI-D0P 0101:TWI0-SCK<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT0 1111:IO Disable  |

### 9.7.5.12 0x0094 PD Configure Register 1 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0094 |            |             | Register Name: PD_CFG1                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                  |
| 31:28          | R/W        | 0xF         | PD15_SELECT<br>PD15 Select<br>0000:Input 0001:Output<br>0010:LCD0-D21 0011:LVDS1-V2N<br>0100:SPI1-WP/DBI-TE 0101:IR-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT15 1111:IO Disable                       |
| 27:24          | R/W        | 0xF         | PD14_SELECT<br>PD14 Select<br>0000:Input 0001:Output<br>0010:LCD0-D20 0011:LVDS1-V2P<br>0100:SPI1-HOLD/DBI-DCX/DBI-WRX 0101:UART3-CTS<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT14 1111:IO Disable        |
| 23:20          | R/W        | 0xF         | PD13_SELECT<br>PD13 Select<br>0000:Input 0001:Output<br>0010:LCD0-D19 0011:LVDS1-V1N<br>0100:SPI1-MISO/DBI-SDI/DBI-TE/DBI-DCX 0101:UART3-RTS<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT13 1111:IO Disable |
| 19:16          | R/W        | 0xF         | PD12_SELECT<br>PD12 Select<br>0000:Input 0001:Output<br>0010:LCD0-D18 0011:LVDS1-V1P<br>0100:SPI1-MOSI/DBI-SDO 0101:TWI0-SDA<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT12 1111:IO Disable                 |

| Offset: 0x0094 |            |             | Register Name: PD_CFG1                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 15:12          | R/W        | 0xF         | PD11_SELECT<br>PD11 Select<br>0000:Input 0001:Output<br>0010:LCD0-D15 0011:LVDS1-VON<br>0100:SPI1-CLK/DBI-SCLK 0101:UART3-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT11 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PD10_SELECT<br>PD10 Select<br>0000:Input 0001:Output<br>0010:LCD0-D14 0011:LVDS1-VOP<br>0100:SPI1-CS/DBI-CSX 0101:UART3-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT10 1111:IO Disable   |
| 7:4            | R/W        | 0xF         | PD9_SELECT<br>PD9 Select<br>0000:Input 0001:Output<br>0010:LCD0-D13 0011:LVDS0-V3N<br>0100:DSI-D3N 0101:PWM6<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT9 1111:IO Disable                  |
| 3:0            | R/W        | 0xF         | PD8_SELECT<br>PD8 Select<br>0000:Input 0001:Output<br>0010:LCD0-D12 0011:LVDS0-V3P<br>0100:DSI-D3P 0101:UART4-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT8 1111:IO Disable              |

### 9.7.5.13 0x0098 PD Configure Register 2 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0098 |            |             | Register Name: PD_CFG2                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 31:28          | /          | /           | /                                                                                                                                                                                                                |
| 27:24          | R/W        | 0xF         | PD22_SELECT<br>PD22 Select<br>0000:Input 0001:Output<br>0010:OWA-OUT 0011:IR-RX<br>0100:UART1-RX 0101:PWM7<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT22 1111:IO Disable       |
| 23:20          | R/W        | 0xF         | PD21_SELECT<br>PD21 Select<br>0000:Input 0001:Output<br>0010:LCD0-VSYNC 0011:TWI2-SDA<br>0100:UART1-TX 0101:PWM5<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT21 1111:IO Disable |
| 19:16          | R/W        | 0xF         | PD20_SELECT<br>PD20 Select<br>0000:Input 0001:Output<br>0010:LCD0-HSYNC 0011:TWI2-SCK<br>0100:DMIC-CLK 0101:PWM4<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT20 1111:IO Disable |
| 15:12          | R/W        | 0xF         | PD19_SELECT<br>PD19 Select<br>0000:Input 0001:Output<br>0010:LCD0-DE 0011:LVDS1-V3N<br>0100:DMIC-DATA0 0101:PWM3<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT19 1111:IO Disable |

| Offset: 0x0098 |            |             | Register Name: PD_CFG2                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 11:8           | R/W        | 0xF         | PD18_SELECT<br>PD18 Select<br>0000:Input 0001:Output<br>0010:LCD0-CLK 0011:LVDS1-V3P<br>0100:DMIC-DATA1 0101:PWM2<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT18 1111:IO Disable |
| 7:4            | R/W        | 0xF         | PD17_SELECT<br>PD17 Select<br>0000:Input 0001:Output<br>0010:LCD0-D23 0011:LVDS1-CKN<br>0100:DMIC-DATA2 0101:PWM1<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT17 1111:IO Disable |
| 3:0            | R/W        | 0xF         | PD16_SELECT<br>PD16 Select<br>0000:Input 0001:Output<br>0010:LCD0-D22 0011:LVDS1-CKP<br>0100:DMIC-DATA3 0101:PWM0<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PD-EINT16 1111:IO Disable |

#### 9.7.5.14 0x00A0 PD Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00A0 |            |             | Register Name: PD_DAT |
|----------------|------------|-------------|-----------------------|
| Bit            | Read/Write | Default/Hex | Description           |
| 31:23          | /          | /           | /                     |

| Offset: 0x00A0 |            |             | Register Name: PD_DAT                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 22:0           | R/W        | 0x0         | <p>PD_DAT</p> <p>PD Data</p> <p>If the port is configured as the input function, the corresponding bit is the pin state. If the port is configured as the output function, the pin state is the same as the corresponding bit. The read bit value is the value set up by software. If the port is configured as a functional pin, the undefined value will be read.</p> |

#### 9.7.5.15 0x00A4 PD Multi\_Driving Register 0 (Default Value: 0x1111\_1111)

| Offset: 0x00A4 |            |             | Register Name: PD_DRV0                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                     |
| 31:30          | /          | /           | /                                                                                                                                                               |
| 29:28          | R/W        | 0x1         | <p>PD7_DRV</p> <p>PD7 Multi_Driving Select.</p> <p>00: Level 0                          01: Level 1</p> <p>10: Level 2                          11: Level 3</p> |
| 27:26          | /          | /           | /                                                                                                                                                               |
| 25:24          | R/W        | 0x1         | <p>PD6_DRV</p> <p>PD6 Multi_Driving Select.</p> <p>00: Level 0                          01: Level 1</p> <p>10: Level 2                          11: Level 3</p> |
| 23:22          | /          | /           | /                                                                                                                                                               |
| 21:20          | R/W        | 0x1         | <p>PD5_DRV</p> <p>PD5 Multi_Driving Select.</p> <p>00: Level 0                          01: Level 1</p> <p>10: Level 2                          11: Level 3</p> |
| 19:18          | /          | /           | /                                                                                                                                                               |
| 17:16          | R/W        | 0x1         | <p>PD4_DRV</p> <p>PD4 Multi_Driving Select.</p> <p>00: Level 0                          01: Level 1</p> <p>10: Level 2                          11: Level 3</p> |
| 15:14          | /          | /           | /                                                                                                                                                               |

| Offset: 0x00A4 |            |             | Register Name: PD_DRV0                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 13:12          | R/W        | 0x1         | PD3_DRV<br>PD3 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                          |
| 9:8            | R/W        | 0x1         | PD2_DRV<br>PD2 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                          |
| 5:4            | R/W        | 0x1         | PD1_DRV<br>PD1 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 3:2            | /          | /           | /                                                                                          |
| 1:0            | R/W        | 0x1         | PDO_DRV<br>PDO Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 9.7.5.16 0x00A8 PD Multi\_Driving Register 1 (Default Value: 0x1111\_1111)

| Offset: 0x00A8 |            |             | Register Name: PD_DRV1                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 31:30          | /          | /           | /                                                                                            |
| 29:28          | R/W        | 0x1         | PD15_DRV<br>PD15 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                            |
| 25:24          | R/W        | 0x1         | PD14_DRV<br>PD14 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                            |

| Offset: 0x00A8 |            |             | Register Name: PD_DRV1                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 21:20          | R/W        | 0x1         | PD13_DRV<br>PD13 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                            |
| 17:16          | R/W        | 0x1         | PD12_DRV<br>PD12 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                            |
| 13:12          | R/W        | 0x1         | PD11_DRV<br>PD11 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                            |
| 9:8            | R/W        | 0x1         | PD10_DRV<br>PD10 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                            |
| 5:4            | R/W        | 0x1         | PD9_DRV<br>PD9 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 3:2            | /          | /           | /                                                                                            |
| 1:0            | R/W        | 0x1         | PD8_DRV<br>PD8 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |

#### 9.7.5.17 0x00AC PD Multi\_Driving Register 2 (Default Value: 0x0111\_1111)

| Offset: 0x00AC |            |             | Register Name: PD_DRV2 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:26          | /          | /           | /                      |

| Offset: 0x00AC |            |             | Register Name: PD_DRV2                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                  |
| 25:24          | R/W        | 0x1         | PD22_DRV<br>PD22 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                            |
| 21:20          | R/W        | 0x1         | PD21_DRV<br>PD21 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                            |
| 17:16          | R/W        | 0x1         | PD20_DRV<br>PD20 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                            |
| 13:12          | R/W        | 0x1         | PD19_DRV<br>PD19 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                            |
| 9:8            | R/W        | 0x1         | PD18_DRV<br>PD18 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                            |
| 5:4            | R/W        | 0x1         | PD17_DRV<br>PD17 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 3:2            | /          | /           | /                                                                                            |
| 1:0            | R/W        | 0x1         | PD16_DRV<br>PD16 Multi_Driving Select.<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

**9.7.5.18 0x00B4 PD Pull Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x00B4 |            |             | Register Name: PD_PULL0                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:30          | R/W        | 0x0         | PD15_PULL<br>PD15 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 29:28          | R/W        | 0x0         | PD14_PULL<br>PD14 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 27:26          | R/W        | 0x0         | PD13_PULL<br>PD13 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 25:24          | R/W        | 0x0         | PD12_PULL<br>PD12 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 23:22          | R/W        | 0x0         | PD11_PULL<br>PD11 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 21:20          | R/W        | 0x0         | PD10_PULL<br>PD10 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 19:18          | R/W        | 0x0         | PD9_PULL<br>PD9 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 17:16          | R/W        | 0x0         | PD8_PULL<br>PD8 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |

| Offset: 0x00B4 |            |             | Register Name: PD_PULL0                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 15:14          | R/W        | 0x0         | PD7_PULL<br>PD7 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 13:12          | R/W        | 0x0         | PD6_PULL<br>PD6 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 11:10          | R/W        | 0x0         | PD5_PULL<br>PD5 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 9:8            | R/W        | 0x0         | PD4_PULL<br>PD4 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 7:6            | R/W        | 0x0         | PD3_PULL<br>PD3 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 5:4            | R/W        | 0x0         | PD2_PULL<br>PD2 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 3:2            | R/W        | 0x0         | PD1_PULL<br>PD1 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 1:0            | R/W        | 0x0         | PD0_PULL<br>PD0 Pull_up or down Select.<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |

## 9.7.5.19 0x00B8 PD Pull Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: PD_PULL1                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:14          | /          | /           | /                                                                                                                                 |
| 13:12          | R/W        | 0x0         | PD22_PULL<br>PD22 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 11:10          | R/W        | 0x0         | PD21_PULL<br>PD21 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 9:8            | R/W        | 0x0         | PD20_PULL<br>PD20 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 7:6            | R/W        | 0x0         | PD19_PULL<br>PD19 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 5:4            | R/W        | 0x0         | PD18_PULL<br>PD18 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 3:2            | R/W        | 0x0         | PD17_PULL<br>PD17 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 1:0            | R/W        | 0x0         | PD16_PULL<br>PD16 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |

### 9.7.5.20 0x00C0 PE Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x00C0 |            |             | Register Name: PE_CFG0                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                     |
| 31:28          | R/W        | 0xF         | PE7_SELECT<br>PE7 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D3 0011:UART5-RX<br>0100:TWI3-SDA 0101:OWA-OUT<br>0110:D-JTAG-CK 0111:Reserved<br>1000:RGMII-CLKIN/RMII-RXER 1001:Reserved<br>1110:PE-EINT7 1111:IO Disable    |
| 27:24          | R/W        | 0xF         | PE6_SELECT<br>PE6 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D2 0011:UART5-TX<br>0100:TWI3-SCK 0101: Reserved<br>0110:D-JTAG-DO 0111:Reserved<br>1000:RMII-TXCTRL/RMII-TXEN 1001:Reserved<br>1110:PE-EINT6 1111:IO Disable  |
| 23:20          | R/W        | 0xF         | PE5_SELECT<br>PE5 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D1 0011:UART4-RX<br>0100:TWI2-SDA 0101:LEDC-DO<br>0110:D-JTAG-DI 0111:Reserved<br>1000:RGMII-TXD1/RMII-TXD1 1001:Reserved<br>1110:PE-EINT5 1111:IO Disable     |
| 19:16          | R/W        | 0xF         | PE4_SELECT<br>PE4 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D0 0011:UART4-TX<br>0100:TWI2-SCK 0101:CLK-FANOUT2<br>0110:D-JTAG-MS 0111:Reserved<br>1000:RGMII-TXD0/RMII-TXD0 1001:Reserved<br>1110:PE-EINT4 1111:IO Disable |

| Offset: 0x00C0 |            |             | Register Name: PE_CFG0                                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                           |
| 15:12          | R/W        | 0xF         | PE3_SELECT<br>PE3 Select<br>0000:Input 0001:Output<br>0010:NCSI0-MCLK 0011:UART2-RX<br>0100:TWI0-SDA 0101:CLK-FANOUT1<br>0110:UART0-RX 0111:Reserved<br>1000:RGMII-TXCK/RMII-TXCK 1001:Reserved<br>1110:PE-EINT3 1111:IO Disable      |
| 11:8           | R/W        | 0xF         | PE2_SELECT<br>PE2 Select<br>0000:Input 0001:Output<br>0010:NCSI0-PCLK 0011:UART2-TX<br>0100:TWI0-SCK 0101:CLK-FANOUT0<br>0110:UART0-TX 0111:Reserved<br>1000:RGMII-RXD1/RMII-RXD1 1001:Reserved<br>1110:PE-EINT2 1111:IO Disable      |
| 7:4            | R/W        | 0xF         | PE1_SELECT<br>PE1 Select<br>0000:Input 0001:Output<br>0010:NCSI0-VSYNC 0011:UART2-CTS<br>0100:TWI1-SDA 0101:LCD0-VSYNC<br>0110:Reserved 0111:Reserved<br>1000:RGMII-RXD0/RMII-RXD0 1001:Reserved<br>1110:PE-EINT1 1111:IO Disable     |
| 3:0            | R/W        | 0xF         | PEO_SELECT<br>PEO Select<br>0000:Input 0001:Output<br>0010:NCSI0-HSYNC 0011:UART2-RTS<br>0100:TWI1-SCK 0101:LCD0-HSYNC<br>0110:Reserved 0111:Reserved<br>1000:RGMII-RXCTRL/RMII-CRS-DV 1001:Reserved<br>1110:PE-EINT0 1111:IO Disable |

### 9.7.5.21 0x00C4 PE Configure Register 1 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x00C4 |            |             | Register Name: PE_CFG1                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 31:28          | R/W        | 0xF         | Reserved                                                                                                                                                                                                                |
| 27:24          | R/W        | 0xF         | Reserved                                                                                                                                                                                                                |
| 23:20          | R/W        | 0xF         | PE13_SELECT<br>PE13 Select<br>0000:Input 0001:Output<br>0010:TWI2-SDA 0011:PWM5<br>0100:Reserved 0101:Reserved<br>0110:DMIC-DATA3 0111:Reserved<br>1000:RGMII-RXD2 1001:Reserved<br>1110:PE-EINT13 1111:IO Disable      |
| 19:16          | R/W        | 0xF         | PE12_SELECT<br>PE12 Select<br>0000:Input 0001:Output<br>0010:TWI2-SCK 0011:NCSI0-FIELD<br>0100:Reserved 0101:Reserved<br>0110:Reserved 0111:Reserved<br>1000:RGMII-TXD3 1001:Reserved<br>1110:PE-EINT12 1111:IO Disable |
| 15:12          | R/W        | 0xF         | PE11_SELECT<br>PE11 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D7 0011:UART1-RX<br>0100:Reserved 0101:Reserved<br>0110:JTAG-CK 0111:Reserved<br>1000:RGMII-TXD2 1001:Reserved<br>1110:PE-EINT11 1111:IO Disable     |
| 11:8           | R/W        | 0xF         | PE10_SELECT<br>PE10 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D6 0011:UART1-TX<br>0100:PWM4 0101:IR-RX<br>0110:JTAG-DO 0111:Reserved<br>1000:EPHY-25M 1001:Reserved<br>1110:PE-EINT10 1111:IO Disable              |

| Offset: 0x00C4 |            |             | Register Name: PE_CFG1                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 7:4            | R/W        | 0xF         | PE9_SELECT<br>PE9 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D5 0011:UART1-CTS<br>0100:PWM3 0101:UART3-RX<br>0110:JTAG-DI 0111:Reserved<br>1000:MDIO 1001:Reserved<br>1110:PE_EINT9 1111:IO Disable |
|                |            |             |                                                                                                                                                                                                         |
|                |            |             | PE8_SELECT<br>PE8 Select<br>0000:Input 0001:Output<br>0010:NCSI0-D4 0011:UART1-RTS<br>0100:PWM2 0101:UART3-TX<br>0110:JTAG-MS 0111:Reserved<br>1000:MDC 1001:Reserved<br>1110:PE_EINT8 1111:IO Disable  |
|                |            |             |                                                                                                                                                                                                         |
|                |            |             |                                                                                                                                                                                                         |
|                |            |             |                                                                                                                                                                                                         |
|                |            |             |                                                                                                                                                                                                         |
|                |            |             |                                                                                                                                                                                                         |

#### 9.7.5.22 0x00D0 PE Data Register (Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: PE_DAT                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                 |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                           |
| 13:0           | R/W        | 0x0         | PE_DAT<br>PE Data<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

## 9.7.5.23 0x00D4 PE Multi\_Driving Register 0 (Default Value: 0x1111\_1111)

| Offset: 0x00D4 |            |             | Register Name: PE_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:30          | /          | /           | /                                                                                         |
| 29:28          | R/W        | 0x1         | PE7_DRV<br>PE7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                         |
| 25:24          | R/W        | 0x1         | PE6_DRV<br>PE6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                         |
| 21:20          | R/W        | 0x1         | PE5_DRV<br>PE5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                         |
| 17:16          | R/W        | 0x1         | PE4_DRV<br>PE4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                         |
| 13:12          | R/W        | 0x1         | PE3_DRV<br>PE3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                         |
| 9:8            | R/W        | 0x1         | PE2_DRV<br>PE2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                         |

| Offset: 0x00D4 |            |             | Register Name: PE_DRV0                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                 |
| 5:4            | R/W        | 0x1         | PE1_DRV<br>PE1 Multi_Driving Select<br>00: Level 0                          01: Level 1<br>10: Level 2                          11: Level 3 |
| 3:2            | /          | /           | /                                                                                                                                           |
| 1:0            | R/W        | 0x1         | PE0_DRV<br>PE0 Multi_Driving Select<br>00: Level 0                          01: Level 1<br>10: Level 2                          11: Level 3 |

#### 9.7.5.24 0x00D8 PE Multi\_Driving Register 1 (Default Value: 0x1111\_1111)

| Offset: 0x00D8 |            |             | Register Name: PE_DRV1                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                   |
| 31:30          | /          | /           | /                                                                                                                                             |
| 29:28          | R/W        | 0x1         | Reserved                                                                                                                                      |
| 27:26          | /          | /           | /                                                                                                                                             |
| 25:24          | R/W        | 0x1         | Reserved                                                                                                                                      |
| 23:22          | /          | /           | /                                                                                                                                             |
| 21:20          | R/W        | 0x1         | PE13_DRV<br>PE13 Multi_Driving Select<br>00: Level 0                          01: Level 1<br>10: Level 2                          11: Level 3 |
| 19:18          | /          | /           | /                                                                                                                                             |
| 17:16          | R/W        | 0x1         | PE12_DRV<br>PE12 Multi_Driving Select<br>00: Level 0                          01: Level 1<br>10: Level 2                          11: Level 3 |
| 15:14          | /          | /           | /                                                                                                                                             |
| 13:12          | R/W        | 0x1         | PE11_DRV<br>PE11 Multi_Driving Select<br>00: Level 0                          01: Level 1<br>10: Level 2                          11: Level 3 |
| 11:10          | /          | /           | /                                                                                                                                             |

| Offset: 0x00D8 |            |             | Register Name: PE_DRV1                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 9:8            | R/W        | 0x1         | PE10_DRV<br>PE10 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                           |
| 5:4            | R/W        | 0x1         | PE9_DRV<br>PE9 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 3:2            | /          | /           | /                                                                                           |
| 1:0            | R/W        | 0x1         | PE8_DRV<br>PE8 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |

#### 9.7.5.25 0x00E4 PE Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x00E4 |            |             | Register Name: PE_PULL0                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31:30          | R/W        | 0x0         | Reserved                                                                                                       |
| 29:28          | R/W        | 0x0         | Reserved                                                                                                       |
| 27:26          | R/W        | 0x0         | PE13_PULL<br>PE13 Pull_up or down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 25:24          | R/W        | 0x0         | PE12_PULL<br>PE12 Pull_up or down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |
| 23:22          | R/W        | 0x0         | PE11_PULL<br>PE11 Pull_up or down Select<br>00: Pull_up/down disable 01: Pull_up<br>10: Pull_down 11: Reserved |

| Offset: 0x00E4 |            |             | Register Name: PE_PULL0                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 21:20          | R/W        | 0x0         | PE10_PULL<br>PE10 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 19:18          | R/W        | 0x0         | PE9_PULL<br>PE9 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 17:16          | R/W        | 0x0         | PE8_PULL<br>PE8 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 15:14          | R/W        | 0x0         | PE7_PULL<br>PE7 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 13:12          | R/W        | 0x0         | PE6_PULL<br>PE6 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 11:10          | R/W        | 0x0         | PE5_PULL<br>PE5 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 9:8            | R/W        | 0x0         | PE4_PULL<br>PE4 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 7:6            | R/W        | 0x0         | PE3_PULL<br>PE3 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 5:4            | R/W        | 0x0         | PE2_PULL<br>PE2 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |

| Offset: 0x00E4 |            |             | Register Name: PE_PULL0                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 3:2            | R/W        | 0x0         | PE1_PULL<br>PE1 Pull_up or down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down                  11: Reserved |
| 1:0            | R/W        | 0x0         | PEO_PULL<br>PEO Pull_up or down Select<br>00: Pull_up/down disable      01: Pull_up<br>10: Pull_down                  11: Reserved |

#### 9.7.5.26 0x00F0 PF Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x00F0 |            |             | Register Name: PF_CFG0                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                  |
| 31:28          | /          | /           | /                                                                                                                                                                                                                                                                                                            |
| 27:24          | R/W        | 0xF         | PF6_SELECT<br>PF6 Select<br>0000:Input                    0001:Output<br>0010:Reserved                0011:OWA-OUT<br>0100:IR-RX                   0101:I2S2-MCLK<br>0110:PWM5                    0111:Reserved<br>1000:Reserved                1001:Reserved<br>1110:PF-EINT6               1111:IO Disable |
| 23:20          | R/W        | 0xF         | PF5_SELECT<br>PF5 Select<br>0000:Input                    0001:Output<br>0010:SDC0-D2                0011:JTAG-CK<br>0100:Reserved                0101:I2S2-LRCK<br>0110:Reserved                0111:Reserved<br>1000:Reserved                1001:Reserved<br>1110:PF-EINT5               1111:IO Disable  |

| Offset: 0x00F0 |            |             | Register Name: PF_CFG0                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 19:16          | R/W        | 0xF         | PF4_SELECT<br>PF4 Select<br>0000:Input 0001:Output<br>0010:SDC0-D3 0011:UART0-RX<br>0100:TWI0-SDA 0101:PWM6<br>0110:IR-TX 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PF-EINT4 1111:IO Disable            |
| 15:12          | R/W        | 0xF         | PF3_SELECT<br>PF3 Select<br>0000:Input 0001:Output<br>0010:SDC0-CMD 0011:JTAG-DO<br>0100:Reserved 0101:I2S2-BCLK<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PF-EINT3 1111:IO Disable    |
| 11:8           | R/W        | 0xF         | PF2_SELECT<br>PF2 Select<br>0000:Input 0001:Output<br>0010:SDC0-CLK 0011:UART0-TX<br>0100:TWI0-SCK 0101: Reserved<br>0110: Reserved 0111: Reserved<br>1000:Reserved 1001:Reserved<br>1110:PF-EINT2 1111:IO Disable |
| 7:4            | R/W        | 0xF         | PF1_SELECT<br>PF1 Select<br>0000:Input 0001:Output<br>0010:SDC0-D0 0011:JTAG-DI<br>0100:Reserved 0101:I2S2-DOUT0<br>0110:I2S2-DIN1 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PF-EINT1 1111:IO Disable   |

| Offset: 0x00FO |            |             | Register Name: PF_CFG0                                                                                                                                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 3:0            | R/W        | 0xF         | PFO_SELECT<br>PFO Select<br>0000:Input 0001:Output<br>0010:SDC0-D1 0011:JTAG-MS<br>0100:Reserved 0101:I2S2-DOUT1<br>0110:I2S2-DINO 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PF-EINT0 1111:IO Disable |

#### 9.7.5.27 0x0100 PF Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: PF_DAT                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                 |
| 31:7           | /          | /           | /                                                                                                                                                                                                                                                                                                                           |
| 6:0            | R/W        | 0           | PF_DAT<br>PF Data<br>If the port is configured as input, the corresponding bit is the pin state. If the port is configured as output, the pin state is the same as the corresponding bit. The read bit value is the value setup by software. If the port is configured as functional pin, the undefined value will be read. |

#### 9.7.5.28 0x0104 PF Multi\_Driving Register 0 (Default Value: 0x0111\_1111)

| Offset: 0x0104 |            |             | Register Name: PF_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:26          | /          | /           | /                                                                                         |
| 25:24          | R/W        | 0x1         | PF6_DRV<br>PF6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                         |

| Offset: 0x0104 |            |             | Register Name: PF_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 21:20          | R/W        | 0x1         | PF5_DRV<br>PF5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                         |
| 17:16          | R/W        | 0x1         | PF4_DRV<br>PF4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                         |
| 13:12          | R/W        | 0x1         | PF3_DRV<br>PF3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                         |
| 9:8            | R/W        | 0x1         | PF2_DRV<br>PF2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                         |
| 5:4            | R/W        | 0x1         | PF1_DRV<br>PF1 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 3:2            | /          | /           | /                                                                                         |
| 1:0            | R/W        | 0x1         | PFO_DRV<br>PFO Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 9.7.5.29 0x0114 PF Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0114 |            |             | Register Name: PF_PULL0 |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:14          | /          | /           | /                       |

| Offset: 0x0114 |            |             | Register Name: PF_PULL0                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 13:12          | R/W        | 0x0         | PF6_PULL<br>PF6 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 11:10          | R/W        | 0x0         | PF5_PULL<br>PF5 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 9:8            | R/W        | 0x0         | PF4_PULL<br>PF4 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 7:6            | R/W        | 0x0         | PF3_PULL<br>PF3 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 5:4            | R/W        | 0x0         | PF2_PULL<br>PF2 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 3:2            | R/W        | 0x0         | PF1_PULL<br>PF1 Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 1:0            | R/W        | 0x0         | PFO_PULL<br>PFO Pull_up or down Select<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |

### 9.7.5.30 0x0120 PG Configure Register 0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0120 |            |             | Register Name: PG_CFG0                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                            |
| 31:28          | R/W        | 0xF         | PG7_SELECT<br>PG7 Select<br>0000:Input 0001:Output<br>0010:UART1-RX 0011:TWI2-SDA<br>0100:RGMII-TXD3 0101: Reserved<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT7 1111:IO Disable     |
| 27:24          | R/W        | 0xF         | PG6_SELECT<br>PG6 Select<br>0000:Input 0001:Output<br>0010:UART1-TX 0011:TWI2-SCK<br>0100:RGMII-TXD2 0101:PWM1<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT6 1111:IO Disable          |
| 23:20          | R/W        | 0xF         | PG5_SELECT<br>PG5 Select<br>0000:Input 0001:Output<br>0010:SDC1-D3 0011:UART5-RX<br>0100:RGMII-TXD1/RMII-TXD1 0101:PWM4<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT5 1111:IO Disable |
| 19:16          | R/W        | 0xF         | PG4_SELECT<br>PG4 Select<br>0000:Input 0001:Output<br>0010:SDC1-D2 0011:UART5-TX<br>0100:RGMII-TXD0/RMII-TXD0 0101:PWM5<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT4 1111:IO Disable |

| Offset: 0x0120 |            |             | Register Name: PG_CFG0                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                 |
| 15:12          | R/W        | 0xF         | PG3_SELECT<br>PG3 Select<br>0000:Input 0001:Output<br>0010:SDC1-D1 0011:UART3-CTS<br>0100:RGMII-TXCK/RMII-TXCK 0101:UART4-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT3 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PG2_SELECT<br>PG2 Select<br>0000:Input 0001:Output<br>0010:SDC1-D0 0011:UART3-RTS<br>0100:RGMII-RXD1/RMII-RXD1 0101:UART4-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT2 1111:IO Disable |
| 7:4            | R/W        | 0xF         | PG1_SELECT<br>PG1 Select<br>0000:Input 0001:Output<br>0010:SDC1-CMD 0011:UART3-RX<br>0100:RGMII-RXD0/RMII-RXD0 0101:PWM6<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT1 1111:IO Disable     |
| 3:0            | R/W        | 0xF         | PG0_SELECT<br>PG0 Select<br>0000:Input 0001:Output<br>0010:SDC1-CLK 0011:UART3-TX<br>0100:RGMII-RXCTRL/RMII-CRS-DV 0101:PWM7<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT0 1111:IO Disable |

## 9.7.5.31 0x0124 PG Configure Register 1 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0124 |            |             | Register Name: PG_CFG1                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
| 31:28          | R/W        | 0xF         | PG15_SELECT<br>PG15 Select<br>0000:Input 0001:Output<br>0010:I2S1-DOUT0 0011:TWI2-SDA<br>0100:MDIO 0101:I2S1-DIN1<br>0110:SPI0-HOLD 0111:UART1-CTS<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT15 1111:IO Disable              |
| 27:24          | R/W        | 0xF         | PG14_SELECT<br>PG14 Select<br>0000:Input 0001:Output<br>0010:I2S1-DIN0 0011:TWI2-SCK<br>0100:MDC 0101:I2S1-DOUT1<br>0110:SPI0-WP 0111:UART1-RTS<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT14 1111:IO Disable                 |
| 23:20          | R/W        | 0xF         | PG13_SELECT<br>PG13 Select.<br>0000:Input 0001:Output<br>0010:I2S1-BCLK 0011:TWI0-SDA<br>0100:RGMII-CLKIN/RMII-RXER 0101:PWM2<br>0110:LEDC-DO 0111:UART1_RX<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT13 1111:IO Disable     |
| 19:16          | R/W        | 0xF         | PG12_SELECT<br>PG12 Select<br>0000:Input 0001:Output<br>0010:I2S1-LRCK 0011:TWI0-SCK<br>0100:RGMII-TXCTRL/RMII-TXEN 0101:CLK-FANOUT2<br>0110:PWM0 0111:UART1-TX<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT12 1111:IO Disable |

| Offset: 0x0124 |            |             | Register Name: PG_CFG1                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 15:12          | R/W        | 0xF         | PG11_SELECT<br>PG11 Select<br>0000:Input 0001:Output<br>0010:I2S1-MCLK 0011:TWI3-SDA<br>0100:EPHY-25M 0101:CLK-FANOUT1<br>0110:TCON-TRIG 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT11 1111:IO Disable |
| 11:8           | R/W        | 0xF         | PG10_SELECT<br>PG10 Select<br>0000:Input 0001:Output<br>0010:PWM3 0011:TWI3-SCK<br>0100:RGMII-RXCK 0101:CLK-FANOUT0<br>0110:IR-RX 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT10 1111:IO Disable        |
| 7:4            | R/W        | 0xF         | PG9_SELECT<br>PG9 Select.<br>0000:Input 0001:Output<br>0010:UART1-CTS 0011:TWI1-SDA<br>0100:RGMII-RXD3 0101:UART3-RX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT9 1111:IO Disable     |
| 3:0            | R/W        | 0xF         | PG8_SELECT<br>PG8 Select<br>0000:Input 0001:Output<br>0010:UART1-RTS 0011:TWI1-SCK<br>0100:RGMII-RXD2 0101:UART3-TX<br>0110:Reserved 0111:Reserved<br>1000:Reserved 1001:Reserved<br>1110:PG-EINT8 1111:IO Disable      |

### 9.7.5.32 0x0130 PG Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: PG_DAT                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 15:0           | R/W        | 0x0         | PG_DAT<br>If the port is configured as the input function, the corresponding bit is the pin state. If the port is configured as the output function, the pin state is the same as the corresponding bit. The read bit value is the value set up by software. If the port is configured as a functional pin, the undefined value will be read. |

### 9.7.5.33 0x0134 PG Multi\_Driving Register 0 (Default Value: 0x1111\_1111)

| Offset: 0x0134 |            |             | Register Name: PG_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 31:30          | /          | /           | /                                                                                         |
| 29:28          | R/W        | 0x1         | PG7_DRV<br>PG7 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                         |
| 25:24          | R/W        | 0x1         | PG6_DRV<br>PG6 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                         |
| 21:20          | R/W        | 0x1         | PG5_DRV<br>PG5 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                         |
| 17:16          | R/W        | 0x1         | PG4_DRV<br>PG4 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                         |

| Offset: 0x0134 |            |             | Register Name: PG_DRV0                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                               |
| 13:12          | R/W        | 0x1         | PG3_DRV<br>PG3 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                         |
| 9:8            | R/W        | 0x1         | PG2_DRV<br>PG2 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                         |
| 5:4            | R/W        | 0x1         | PG1_DRV<br>PG1 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 3:2            | /          | /           | /                                                                                         |
| 1:0            | R/W        | 0x1         | PG0_DRV<br>PG0 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 9.7.5.34 0x0138 PG Multi\_Driving Register 1 (Default Value: 0x1111\_1111)

| Offset: 0x0138 |            |             | Register Name: PG_DRV1                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:30          | /          | /           | /                                                                                           |
| 29:28          | R/W        | 0x1         | PG15_DRV<br>PG15 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 27:26          | /          | /           | /                                                                                           |
| 25:24          | R/W        | 0x1         | PG14_DRV<br>PG14 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 23:22          | /          | /           | /                                                                                           |

| Offset: 0x0138 |            |             | Register Name: PG_DRV1                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 21:20          | R/W        | 0x1         | PG13_DRV<br>PG13 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 19:18          | /          | /           | /                                                                                           |
| 17:16          | R/W        | 0x1         | PG12_DRV<br>PG12 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 15:14          | /          | /           | /                                                                                           |
| 13:12          | R/W        | 0x1         | PG11_DRV<br>PG11 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 11:10          | /          | /           | /                                                                                           |
| 9:8            | R/W        | 0x1         | PG10_DRV<br>PG10 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |
| 7:6            | /          | /           | /                                                                                           |
| 5:4            | R/W        | 0x1         | PG9_DRV<br>PG9 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |
| 3:2            | /          | /           | /                                                                                           |
| 1:0            | R/W        | 0x1         | PG8_DRV<br>PG8 Multi_Driving Select<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3   |

## 9.7.5.35 0x0144 PG Pull Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0144 |            |             | Register Name: PG_PULL0                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:30          | R/W        | 0x0         | PG15_PULL<br>PG15 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 29:28          | R/W        | 0x0         | PG14_PULL<br>PG14 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 27:26          | R/W        | 0x0         | PG13_PULL<br>PG13 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 25:24          | R/W        | 0x0         | PG12_PULL<br>PG12 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 23:22          | R/W        | 0x0         | PG11_PULL<br>PG11 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 21:20          | R/W        | 0x0         | PG10_PULL<br>PG10 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 19:18          | R/W        | 0x0         | PG9_PULL<br>PG9 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |
| 17:16          | R/W        | 0x0         | PG8_PULL<br>PG8 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved   |

| Offset: 0x0144 |            |             | Register Name: PG_PULL0                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                     |
| 15:14          | R/W        | 0x0         | PG7_PULL<br>PG7 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 13:12          | R/W        | 0x0         | PG6_PULL<br>PG6 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 11:10          | R/W        | 0x0         | PG5_PULL<br>PG5 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 9:8            | R/W        | 0x0         | PG4_PULL<br>PG4 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 7:6            | R/W        | 0x0         | PG3_PULL<br>PG3 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 5:4            | R/W        | 0x0         | PG2_PULL<br>PG2 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 3:2            | R/W        | 0x0         | PG1_PULL<br>PG1 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |
| 1:0            | R/W        | 0x0         | PG0_PULL<br>PG0 Pull_up or down Select.<br>00: Pull_up/down disable    01: Pull_up<br>10: Pull_down                11: Reserved |

**9.7.5.36 0x0220 PB External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)**

| Offset: 0x0220 |            |             | Register Name:PB_EINT_CFG0                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0220 |            |             | Register Name: PB_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | Reserved                                                                                                                                                                     |
| 3:0            | R/W        | 0x0         | Reserved                                                                                                                                                                     |

#### 9.7.5.37 0x0230 PB External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: PB_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:8           | /          | /           | /                                                            |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable |

| Offset: 0x0230 |            |             | Register Name: PB_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | Reserved                                                     |
| 0              | R/W        | 0x0         | Reserved                                                     |

#### 9.7.5.38 0x0234 PB External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: PB_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7              | R/W1C      | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x0234 |            |             | Register Name: PB_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W        | 0x0         | Reserved                                                                                               |
| 0              | R/W        | 0x0         | Reserved                                                                                               |

#### 9.7.5.39 0x0238 PB External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: PB_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |

| Offset: 0x0238 |            |             | Register Name: PB_EINT_DEB                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz |

#### 9.7.5.40 0x0240 PC External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0240 |            |             | Register Name: PC_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0240 |            |             | Register Name: PC_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | Reserved                                                                                                                                                                     |
| 3:0            | R/W        | 0x0         | Reserved                                                                                                                                                                     |

#### 9.7.5.41 0x0250 PC External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0250 |            |             | Register Name: PC_EINT_CTL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:8           | /          | /           | /                          |

| Offset: 0x0250 |            |             | Register Name: PC_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | Reserved                                                     |
| 0              | R/W        | 0x0         | Reserved                                                     |

#### 9.7.5.42 0x0254 PC External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0254 |            |             | Register Name: PC_EINT_STATUS |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:8           | /          | /           | /                             |

| Offset: 0x0254 |            |             | Register Name: PC_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 7              | R/W1C      | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W        | 0x0         | Reserved                                                                                               |
| 0              | R/W        | 0x0         | Reserved                                                                                               |

#### 9.7.5.43 0x0258 PC External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0258 |            |             | Register Name: PC_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz                   |

#### 9.7.5.44 0x0260 PD External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0260 |            |             | Register Name: PD_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0260 |            |             | Register Name: PD_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0260 |            |             | Register Name: PD_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.45 0x0264 PD External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0264 |            |             | Register Name: PD_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT15_CFG<br>External INT15 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0264 |            |             | Register Name:PD_EINT_CFG1                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 27:24          | R/W        | 0x0         | EINT14_CFG<br>External INT14 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0264 |            |             | Register Name:PD_EINT_CFG1                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |

#### 9.7.5.46 0x0268 PD External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0268 |            |             | Register Name:PD_EINT_CFG2 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:28          | /          | /           | /                          |

| Offset: 0x0268 |            |             | Register Name:PD_EINT_CFG2                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 27:24          | R/W        | 0x0         | EINT22_CFG<br>External INT22 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT21_CFG<br>External INT21 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT20_CFG<br>External INT20 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT19_CFG<br>External INT19 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0268 |            |             | Register Name: PD_EINT_CFG2                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
| 11:8           | R/W        | 0x0         | <p>EINT18_CFG</p> <p>External INT18 Mode</p> <p>0x0: Positive Edge</p> <p>0x1: Negative Edge</p> <p>0x2: High Level</p> <p>0x3: Low Level</p> <p>0x4: Double Edge (Positive/Negative)</p> <p>Others: Reserved</p> |
| 7:4            | R/W        | 0x0         | <p>EINT17_CFG</p> <p>External INT17 Mode</p> <p>0x0: Positive Edge</p> <p>0x1: Negative Edge</p> <p>0x2: High Level</p> <p>0x3: Low Level</p> <p>0x4: Double Edge (Positive/Negative)</p> <p>Others: Reserved</p> |
| 3:0            | R/W        | 0x0         | <p>EINT16_CFG</p> <p>External INT16 Mode</p> <p>0x0: Positive Edge</p> <p>0x1: Negative Edge</p> <p>0x2: High Level</p> <p>0x3: Low Level</p> <p>0x4: Double Edge (Positive/Negative)</p> <p>Others: Reserved</p> |

#### 9.7.5.47 0x0270 PD External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0270 |            |             | Register Name: PD_EINT_CTL                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:23          | /          | /           | /                                                                                 |
| 22             | R/W        | 0x0         | <p>EINT22_CTL</p> <p>External INT22 Enable</p> <p>0: Disable</p> <p>1: Enable</p> |

| Offset: 0x0270 |            |             | Register Name: PD_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 21             | R/W        | 0x0         | EINT21_CTL<br>External INT21 Enable<br>0: Disable<br>1: Enable |
| 20             | R/W        | 0x0         | EINT20_CTL<br>External INT20 Enable<br>0: Disable<br>1: Enable |
| 19             | R/W        | 0x0         | EINT19_CTL<br>External INT19 Enable<br>0: Disable<br>1: Enable |
| 18             | R/W        | 0x0         | EINT18_CTL<br>External INT18 Enable<br>0: Disable<br>1: Enable |
| 17             | R/W        | 0x0         | EINT17_CTL<br>External INT17 Enable<br>0: Disable<br>1: Enable |
| 16             | R/W        | 0x0         | EINT16_CTL<br>External INT16 Enable<br>0: Disable<br>1: Enable |
| 15             | R/W        | 0x0         | EINT15_CTL<br>External INT15 Enable<br>0: Disable<br>1: Enable |
| 14             | R/W        | 0x0         | EINT14_CTL<br>External INT14 Enable<br>0: Disable<br>1: Enable |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |

| Offset: 0x0270 |            |             | Register Name: PD_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10             | R/W        | 0x0         | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8              | R/W        | 0x0         | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |

| Offset: 0x0270 |            |             | Register Name: PD_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 9.7.5.48 0x0274 PD External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0274 |            |             | Register Name: PD_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:23          | /          | /           | /                                                                                                        |
| 22             | R/W1C      | 0x0         | EINT22_STATUS<br>External INT22 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 21             | R/W1C      | 0x0         | EINT21_STATUS<br>External INT21 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x0274 |            |             | Register Name: PD_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 20             | R/W1C      | 0x0         | EINT20_STATUS<br>External INT20 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 19             | R/W1C      | 0x0         | EINT19_STATUS<br>External INT19 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 18             | R/W1C      | 0x0         | EINT18_STATUS<br>External INT18 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 17             | R/W1C      | 0x0         | EINT17_STATUS<br>External INT17 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 16             | R/W1C      | 0x0         | EINT16_STATUS<br>External INT16 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 15             | R/W1C      | 0x0         | EINT15_STATUS<br>External INT15 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 14             | R/W1C      | 0x0         | EINT14_STATUS<br>External INT14 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x0274 |            |             | Register Name: PD_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 13             | R/W1C      | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W1C      | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W1C      | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10             | R/W1C      | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W1C      | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W1C      | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7              | R/W1C      | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

| Offset: 0x0274 |            |             | Register Name: PD_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W1C      | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0              | R/W1C      | 0x0         | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 9.7.5.49 0x0278 PD External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0278 |            |             | Register Name: PD_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz                   |

#### 9.7.5.50 0x0280 PE External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0280 |            |             | Register Name: PE_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0280 |            |             | Register Name:PE_EINT_CFG0                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0280 |            |             | Register Name: PE_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.51 0x0284 PE External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0284 |            |             | Register Name: PE_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | Reserved                                                                                                                                                                       |
| 27:24          | R/W        | 0x0         | Reserved                                                                                                                                                                       |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x0284 |            |             | Register Name: PE_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved   |

| Offset: 0x0284 |            |             | Register Name: PE_EINT_CFG1                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.52 0x0290 PE External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0290 |            |             | Register Name: PE_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:14          | /          | /           | /                                                              |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10             | R/W        | 0x0         | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |

| Offset: 0x0290 |            |             | Register Name: PE_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 8              | R/W        | 0x0         | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

**9.7.5.53 0x0294 PE External Interrupt Status Register (Default Value: 0x0000\_0000)**

| Offset: 0x0294 |            |             | Register Name: PE_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:14          | /          | /           | /                                                                                                        |
| 13             | R/W1C      | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W1C      | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W1C      | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10             | R/W1C      | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W1C      | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W1C      | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

| Offset: 0x0294 |            |             | Register Name: PE_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 7              | R/W1C      | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W1C      | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x0294 |            |             | Register Name: PE_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 0              | R/W1C      | 0x0         | EINT0_STATUS<br>External INTO Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 9.7.5.54 0x0298 PE External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x0298 |            |             | Register Name: PE_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz                   |

#### 9.7.5.55 0x02A0 PF External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x02A0 |            |             | Register Name: PF_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | /          | /           | /                                                                                                                                                                            |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02A0 |            |             | Register Name: PF_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02A0 |            |             | Register Name: PF_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.56 0x02B0 PF External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x02B0 |            |             | Register Name: PF_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:7           | /          | /           | /                                                            |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |

| Offset: 0x02B0 |            |             | Register Name: PF_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 9.7.5.57 0x02B4 PF External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x02B4 |            |             | Register Name: PF_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:7           | /          | /           | /                                                                                                      |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x02B4 |            |             | Register Name: PF_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W1C      | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0              | R/W1C      | 0x0         | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 9.7.5.58 0x02B8 PF External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x02B8 |            |             | Register Name: PF_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |

| Offset: 0x02B8 |            |             | Register Name: PF_EINT_DEB                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz |

#### 9.7.5.59 0x02C0 PG External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x02C0 |            |             | Register Name: PG_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31:28          | R/W        | 0x0         | EINT7_CFG<br>External INT7 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT6_CFG<br>External INT6 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02C0 |            |             | Register Name: PG_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02C0 |            |             | Register Name: PG_EINT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INTO Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.60 0x02C4 PG External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x02C4 |            |             | Register Name: PG_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 31:28          | R/W        | 0x0         | EINT15_CFG<br>External INT15 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 27:24          | R/W        | 0x0         | EINT14_CFG<br>External INT14 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02C4 |            |             | Register Name: PG_EINT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

| Offset: 0x02C4 |            |             | Register Name: PG_EINT_CFG1                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge (Positive/Negative)<br>Others: Reserved |

#### 9.7.5.61 0x02D0 PG External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x02D0 |            |             | Register Name: PG_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:16          | /          | /           | /                                                              |
| 15             | R/W        | 0x0         | EINT15_CTL<br>External INT15 Enable<br>0: Disable<br>1: Enable |
| 14             | R/W        | 0x0         | EINT14_CTL<br>External INT14 Enable<br>0: Disable<br>1: Enable |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |

| Offset: 0x02D0 |            |             | Register Name: PG_EINT_CTL                                     |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | EINT11_CTL<br>External INT11 Enable<br>0: Disable<br>1: Enable |
| 10             | R/W        | 0x0         | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8              | R/W        | 0x0         | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |

| Offset: 0x02D0 |            |             | Register Name: PG_EINT_CTL                                   |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 9.7.5.62 0x02D4 PG External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x02D4 |            |             | Register Name: PG_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:16          | /          | /           | /                                                                                                        |
| 15             | R/W1C      | 0x0         | EINT15_STATUS<br>External INT15 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 14             | R/W1C      | 0x0         | EINT14_STATUS<br>External INT14 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

| Offset: 0x02D4 |            |             | Register Name: PG_EINT_STATUS                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 13             | R/W1C      | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W1C      | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W1C      | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10             | R/W1C      | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W1C      | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W1C      | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7              | R/W1C      | 0x0         | EINT7_STATUS<br>External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |

| Offset: 0x02D4 |            |             | Register Name: PG_EINT_STATUS                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 6              | R/W1C      | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W1C      | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W1C      | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W1C      | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W1C      | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W1C      | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0              | R/W1C      | 0x0         | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

### 9.7.5.63 0x02D8 PG External Interrupt Debounce Register (Default Value: 0x0000\_0000)

| Offset: 0x02D8 |            |             | Register Name: PG_EINT_DEB                                                                           |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:7           | /          | /           | /                                                                                                    |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1            | /          | /           | /                                                                                                    |
| 0              | R/W        | 0x0         | PIO_INT_CLK_SELECT<br>PIO Interrupt Clock Select<br>0: LOSC 32KHz<br>1: HOSC 24MHz                   |

### 9.7.5.64 0x0340 PIO Group Withstand Voltage Mode Select Register (Default Value: 0x0000\_0000)

When the power domain of GPIO is larger than 1.8 V, the withstand voltage is set to 3.3 V mode, the corresponding value in the 0x0340 register is set to 0.

When the power domain of GPIO is 1.8 V, the withstand voltage is set to 1.8 V mode, the corresponding value in the 0x0340 register is set to 1.

| Offset: 0x0340 |            |             | Register Name: PIO_POW_MOD_SEL                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:13          | /          | /           | /                                                                                                                              |
| 12             | R/W        | 0x0         | VCCIO_PWR_MOD_SEL<br>VCC_IO POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V                                                          |
| 11:7           | /          | /           | /                                                                                                                              |
| 6              | R/W        | 0x0         | PG_PWR_MOD_SEL<br>PG_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PG_Port Power Source selects VCC_IO, this bit is invalid. |

| Offset: 0x0340 |            |             | Register Name: PIO_POW_MOD_SEL                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 5              | R/W        | 0x0         | PF_PWR_MOD_SEL<br>PF_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PF_Port Power Source selects VCC_IO, this bit is invalid. |
| 4              | R/W        | 0x0         | PE_PWR_MOD_SEL<br>PE_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PE_Port Power Source selects VCC_IO, this bit is invalid. |
| 3              | R/W        | 0x0         | PD_PWR_MOD_SEL<br>PD_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PD_Port Power Source selects VCC_IO, this bit is invalid. |
| 2              | R/W        | 0x0         | PC_PWR_MOD_SEL<br>PC_POWER MODE Select<br>0: 3.3 V<br>1: 1.8 V<br>If PC_Port Power Source selects VCC_IO, this bit is invalid. |
| 1:0            | /          | /           | /                                                                                                                              |

#### 9.7.5.65 0x0344 PIO Group Withstand Voltage Mode Select Control Register (Default Value: 0x0000\_0000)

For 1.8 V and 3.3 V power, the withstand function is enabled by default, the corresponding bit in the 0x0344 register is set to 0.

For 2.5 V power, the withstand function is disabled, the corresponding bit in the 0x0344 register is set to 1, and the corresponding withstand voltage in the 0x0340 register needs to be set to 3.3 V.

| Offset: 0x0344 |            |             | Register Name: PIO_POW_MS_CTL                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:13          | /          | /           | /                                                                                               |
| 12             | R/W        | 0x0         | VCCIO_WS_VOL_MOD_SEL<br>VCC_IO Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |

| Offset: 0x0344 |            |             | Register Name: PIO_POW_MS_CTL                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 11:7           | /          | /           | /                                                                                                |
| 6              | R/W        | 0x0         | VCC_PG_WS_VOL_MOD_SEL<br>VCC_PG Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 5              | R/W        | 0x0         | VCC_PF_WS_VOL_MOD_SEL<br>VCC_PF Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 4              | R/W        | 0x0         | VCC_PE_WS_VOL_MOD_SEL<br>VCC_PE Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 3              | R/W        | 0x0         | VCC_PD_WS_VOL_MOD_SEL<br>VCC_PD Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 2              | R/W        | 0x0         | VCC_PC_WS_VOL_MOD_SEL<br>VCC_PC Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 1:0            | /          | /           | /                                                                                                |

#### 9.7.5.66 0x0348 PIO Group Power Value Register (Default Value: 0x0000\_0000)

When the reading value of the 0x0348 register is 0, it indicates that the IO power voltage is greater than 2.5 V.

When the reading value of the 0x0348 register is 1, it indicates that the IO power voltage is less than 2.0 V.

| Offset: 0x0348 |            |             | Register Name: PIO_POW_VAL          |
|----------------|------------|-------------|-------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                         |
| 31:17          | /          | /           | /                                   |
| 16             | R          | 0x0         | VCCIO_PWR_VAL<br>VCC_IO Power Value |
| 15:7           | /          | /           | /                                   |

| Offset: 0x0348 |            |             | Register Name: PIO_POW_VAL                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 6              | R          | 0x0         | PG_PWR_VAL<br>PG_Port Power Value<br>If PG_Port power source selects VCC_IO, this bit is invalid. |
| 5              | R          | 0x0         | PF_PWR_VAL<br>PF_Port Power Value<br>If PF_Port power source selects VCC_IO, this bit is invalid. |
| 4              | R          | 0x0         | PE_PWR_VAL<br>PE_Port Power Value<br>If PE_Port power source selects VCC_IO, this bit is invalid. |
| 3              | R          | 0x0         | PD_PWR_VAL<br>PD_Port Power Value<br>If PD_Port power source selects VCC_IO, this bit is invalid. |
| 2              | R          | 0x0         | PC_PWR_VAL<br>PC_Port Power Value<br>If PC_Port power source selects VCC_IO, this bit is invalid. |
| 1:0            | /          | /           | /                                                                                                 |

#### 9.7.5.67 0x0350 PIO Group Power Voltage Select Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0350 |            |             | Register Name: PIO_POW_VOL_SEL_CTL                          |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:1           | /          | /           | /                                                           |
| 0              | R/W        | 0x1         | VCC-PF Power Voltage Select Control<br>0: 1.8 V<br>1: 3.3 V |

## 9.8 GPADC

### 9.8.1 Overview

The General Purpose ADC (GPADC) can convert the external signal into a certain proportion of digital value, to realize the measurement of analog signal, which can be applied to power detection and key detection. This ADC is a type of successive approximation register (SAR) A/D converter.

The GPADC has the following features:

- One independent channel
- 12-bit sampling resolution and 8-bit precision
- 64 FIFO depth of data register
- Power reference voltage: AVCC, and analog input voltage range: 0 to AVCC
- Maximum sampling frequency: 1 MHz
- Supports data compare and interrupt
- Supports three operation modes
  - Single conversion mode
  - Continuous conversion mode
  - Burst conversion mode

### 9.8.2 Block Diagram

Figure 9-70 shows the block diagram of the GPADC.

Figure 9-70 GPADC Block Diagram



### 9.8.3 Functional Description

#### 9.8.3.1 External Signals

The following table describes the external signals of the GPADC.

Table 9-28 GPADC External Signals

| Signal | Description        | Type |
|--------|--------------------|------|
| GPADC0 | ADC Input Channel0 | AI   |

#### 9.8.3.2 Clock Sources

The GPADC has one clock source. The following table describes the clock source for GPADC. Users can see section 3.3 “[CCU](#)” for clock setting, configuration, and gating information.

Table 9-29 GPADC Clock Sources

| Clock Sources | Description |
|---------------|-------------|
| HOSC          | 24 MHz      |

#### 9.8.3.3 GPADC Work Mode

- **Single conversion mode**

The GPADC completes one conversion in a specified channel, the converted data is updated at the data register of the corresponding channel.

- **Continuous conversion mode**

The GPADC has continuous conversion in a specified channel until the software stops, the converted data is updated at the data register of the corresponding channel.

- **Burst conversion mode**

The GPADC samples and converts in a specified channel, and sequentially stores the results in FIFO.

#### 9.8.3.4 Clock and Timing Requirements

CLK\_IN = 24 MHz

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

TACQ > 10RC (R is output impedance of ADC sample circuit, C = 6.4 pF)

ADC Sample Frequency > TACQ+CONV\_TIME

**Figure 9-71 GPADC Clock and Timing Requirement**



#### 9.8.3.5 GPADC Calculate Formula

GPADC calculate formula: GPADC\_DATA =  $V_{in}/V_{REF} * 4095$

Where:

$V_{REF} = 1.8 \text{ V}$

#### 9.8.4 Programming Guidelines

The GPADC initial process is as follows.

Figure 9-72 GPADC Initial Process



## (1).Query Mode

- Step 1** Write 0x1 to the bit[16] of [GPADC\\_BGR\\_REG](#) to dessert reset.
- Step 2** Write 0x1 to the bit[0] of [GPADC\\_BGR\\_REG](#) to enable the GPADC clock.
- Step 3** Write 0x2F to the bit[15:0] of [GP\\_SR\\_CON](#) to set the *acquiring time of ADC*.
- Step 4** Write 0x1DF to the bit[31:16] of [GP\\_SR\\_CON](#) to set the *ADC sample frequency divider*.
- Step 5** Write 0x2 to the bit[19:18] of [GP\\_CTRL](#) to set the *continuous conversion mode*.
- Step 6** Write 0x1 to the bit[0] of [GP\\_CS\\_EN](#) to enable the *analog input channel*.
- Step 7** Write 0x1 to the bit[16] of [GP\\_CTRL](#) to enable the ADC function.
- Step 8** Read the bit[0] of [GP\\_DATA\\_INTS](#), if the bit is 1, then data conversion is complete.
- Step 9** Read the bit[11:0] of [GP\\_CHO\\_DATA](#), and calculate voltage value based on GPADC formula.

## (2).Interrupt Mode

- Step 1** Write 0x1 to the bit[16] of [GPADC\\_BGR\\_REG](#) to dessert reset.
- Step 2** Write 0x1 to the bit[0] of [GPADC\\_BGR\\_REG](#) to enable the GPADC clock.
- Step 3** Write 0x2F to the bit[15:0] of [GP\\_SR\\_CON](#) to set the *acquiring time of ADC*.
- Step 4** Write 0x1DF to the bit[31:16] of [GP\\_SR\\_CON](#) to set the *ADC sample frequency divider*.
- Step 5** Write 0x2 to the bit[19:18] of [GP\\_CTRL](#) to set the *continuous conversion mode*.

**Step 6** Write 0x1 to the bit[0] of **GP\_CS\_EN** to enable the *analog input channel*.

**Step 7** Write 0x1 to the bit[0] of **GP\_DATA\_INTC** to enable the GPADC data interrupt.

**Step 8** Set interrupt based on GIC module.

**Step 9** Put interrupt handler address into interrupt vector table.

**Step 10** Write 0x1 to the bit16 of **GP\_CTRL** to enable the ADC function.

**Step 11** Read the bit[11:0] of **GP\_CHO\_DATA** from the interrupt handler, calculate voltage value based on GPADC formula.

### 9.8.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| GPADC       | 0x02009000   |

| Register Name   | Offset | Description                                  |
|-----------------|--------|----------------------------------------------|
| GP_SR_CON       | 0x0000 | GPADC Sample Rate Configure Register         |
| GP_CTRL         | 0x0004 | GPADC Control Register                       |
| GP_CS_EN        | 0x0008 | GPADC Compare and Select Enable Register     |
| GP_FIFO_INTC    | 0x000C | GPADC FIFO Interrupt Control Register        |
| GP_FIFO_INTS    | 0x0010 | GPADC FIFO Interrupt Status Register         |
| GP_FIFO_DATA    | 0x0014 | GPADC FIFO Data Register                     |
| GP_CDATA        | 0x0018 | GPADC Calibration Data Register              |
| GP_DATAL_INTC   | 0x0020 | GPADC Data Low Interrupt Configure Register  |
| GP_DATAH_INTC   | 0x0024 | GPADC Data High Interrupt Configure Register |
| GP_DATA_INTC    | 0x0028 | GPADC Data Interrupt Configure Register      |
| GP_DATAL_INTS   | 0x0030 | GPADC Data Low Interrupt Status Register     |
| GP_DATAH_INTS   | 0x0034 | GPADC Data High Interrupt Status Register    |
| GP_DATA_INTS    | 0x0038 | GPADC Data Interrupt Status Register         |
| GP_CHO_CMP_DATA | 0x0040 | GPADC CH0 Compare Data Register              |
| GP_CHO_DATA     | 0x0080 | GPADC CH0 Data Register                      |

### 9.8.6 Register Description

#### 9.8.6.1 0x0000 GPADC Sample Rate Configure Register (Default Value: 0x01DF\_002F)

| Offset: 0x0000 |            |             | Register Name: GP_SR_CON                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31: 16         | R/W        | 0x1DF       | FS_DIV<br>ADC sample frequency divider<br>CLK_IN/(n+1)<br>Default value: 50K |
| 15: 0          | R/W        | 0x2F        | TACQ<br>ADC acquire time<br>(n+1)/CLK_IN<br>Default value: 2 us              |

#### 9.8.6.2 0x0004 GPADC Control Register (Default Value: 0x0080\_0000)

| Offset: 0x0004 |            |             | Register Name: GP_CTRL                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:24          | R/W        | 0x0         | ADC_FIRST_DLY<br>ADC First Convert Delay Setting<br>ADC conversion of each channel is delayed by N samples.                  |
| 23             | R/W        | 0x1         | ADC_AUTO_CAL_EN<br>ADC Auto Calibration                                                                                      |
| 22             | /          | /           | /                                                                                                                            |
| 21:20          | R/W        | 0x0         | ADC_OP_BIAS<br>ADC OP Bias<br>Adjust the bandwidth of the ADC amplifier                                                      |
| 19:18          | R/W        | 0x0         | GPADC Work Mode<br>00: Single conversion mode<br>01: Reserved<br>10: Continuous conversion mode<br>11: Burst conversion mode |
| 17             | R/W        | 0x0         | ADC_CALI_EN<br>ADC Calibration<br>1: Start Calibration, it is cleared to 0 after calibration                                 |

| Offset: 0x0004 |            |             | Register Name: GP_CTRL                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                  |
| 16             | R/W        | 0x0         | <p>ADC_EN<br/>ADC Function Enable<br/>Before the bit is enabled, configure ADC parameters including the work mode and channel number, etc.<br/>0: Disable<br/>1: Enable</p> <p><b>Note:</b> When selecting a single conversion mode, the bit can be cleared automatically after the switch is completed.</p> |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                            |

#### 9.8.6.3 0x0008 GPADC Compare and Select Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: GP_CS_EN                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:17          | /          | /           | /                                                                                    |
| 16             | R/W        | 0x0         | <p>ADC_CHO_CMP_EN<br/>Channel 0 Compare Enable<br/>0: Disable<br/>1: Enable</p>      |
| 15:1           | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | <p>ADC_CHO_SELECT<br/>Analog Input Channel 0 Select<br/>0: Disable<br/>1: Enable</p> |

#### 9.8.6.4 0x000C GPADC FIFO Interrupt Control Register (Default Value: 0x0000\_1F00)

| Offset: 0x000C |            |             | Register Name: GP_FIFO_INTC                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:19          | /          | /           | /                                                                                 |
| 18             | R/W        | 0x0         | <p>FIFO_DATA_DRQ_EN<br/>ADC FIFO Date DRQ Enable<br/>0: Disable<br/>1: Enable</p> |

| Offset: 0x000C |            |             | Register Name: GP_FIFO_INTC                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 17             | R/W        | 0x0         | FIFO_OVERRUN_IRQ_EN<br>ADC FIFO Overrun IRQ Enable<br>0: Disable<br>1: Enable           |
| 16             | R/W        | 0x0         | FIFO_DATA_IRQ_EN<br>ADC FIFO Data Available IRQ Enable<br>0: Disable<br>1: Enable       |
| 15:14          | /          | /           | /                                                                                       |
| 13:8           | R/W        | 0x1F        | FIFO_TRIG_LEVEL<br>Interrupt trigger level for ADC<br>Trigger Level = TXTL + 1          |
| 7:5            | /          | /           | /                                                                                       |
| 4              | R/WAC      | 0x0         | FIFO_FLUSH<br>ADC FIFO Flush<br>Write '1' to flush TX FIFO, clear automatically to '0'. |
| 3:0            | /          | /           | /                                                                                       |

#### 9.8.6.5 0x0010 GPADC FIFO Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: GP_FIFO_INTS                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 31:18          | /          | /           | /                                                                                                                                                                                                            |
| 17             | R/W1C      | 0x0         | FIFO_OVERRUN_PENDING<br>ADC FIFO Overrun IRQ Pending<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails.       |
| 16             | R/W1C      | 0x0         | FIFO_DATA_PENDING<br>ADC FIFO Data Available Pending Bit<br>0: NO Pending IRQ<br>1: FIFO Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails. |

| Offset: 0x0010 |            |             | Register Name: GP_FIFO_INTS                       |
|----------------|------------|-------------|---------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                       |
| 15:14          | /          | /           | /                                                 |
| 13:8           | R          | 0x0         | RXA_CNT<br>ADC FIFO available sample word counter |
| 7:0            | /          | /           | /                                                 |

#### 9.8.6.6 0x0014 GPADC FIFO Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: GP_FIFO_DATA        |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:12          | /          | /           | /                                  |
| 11:0           | R          | 0x0         | GP_FIFO_DATA<br>GPADC Data in FIFO |

#### 9.8.6.7 0x0018 GPADC Calibration Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: GP_CDATA            |
|----------------|------------|-------------|------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                        |
| 31:12          | /          | /           | /                                  |
| 11:0           | R/W        | 0x0         | GP_CDATA<br>GPADC Calibration Data |

#### 9.8.6.8 0x0020 GPADC Low Interrupt Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: GP_DATAL_INTC                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:1           | /          | /           | /                                                                                             |
| 0              | R/W        | 0x0         | CHO_LOW_IRQ_EN<br>Channel 0 Voltage Low Available Interrupt Enable<br>0: Disable<br>1: Enable |

#### 9.8.6.9 0x0024 GPADC High Interrupt Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: GP_DATAH_INTC                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31:1           | /          | /           | /                                                                                              |
| 0              | R/W        | 0x0         | CH0_HIG_IRQ_EN<br>Channel 0 Voltage High Available Interrupt Enable<br>0: Disable<br>1: Enable |

#### 9.8.6.10 0x0028 GPADC DATA Interrupt Configure Register (Default Value: 0x0000\_0000)

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

#### 9.8.6.11 0x0030 GPADC Low Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: GP_DATAL_INTS                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                               |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                         |
| 0              | R/W1C      | 0x0         | CH0_LOW_PENGDING<br>Channel 0 Voltage Low Available Interrupt Status<br>0: NO Pending IRQ<br>1: Channel 0 Voltage Low Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails. |

### 9.8.6.12 0x0034 GPADC High Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: GP_DATAH_INTS                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:1           | /          | /           | /                                                                                                                                                                                      |
| 0              | R/W1C      | 0x0         | CH0_HIG_PENGDING<br>0: No Pending IRQ<br>1: Channel 0 Voltage High Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails. |

### 9.8.6.13 0x0038 GPADC Data Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: GP_DATA_INTS                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:1           | /          | /           | /                                                                                                                                                                                                                            |
| 0              | R/W1C      | 0x0         | CH0_DATA_PENGDING<br>Channel 0 Data Available Interrupt Status<br>0: No Pending IRQ<br>1: Channel 0 Data Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if the interrupt condition fails. |

### 9.8.6.14 0x0040 GPADC CH0 Compare Data Register (Default Value: 0xBFF\_0400)

| Offset: 0x0040 |            |             | Register Name: GP_CH0_CMP_DATA                   |
|----------------|------------|-------------|--------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                      |
| 31:28          | /          | /           | /                                                |
| 27:16          | R/W        | 0xBFF       | CH0_CMP_HIG_DATA<br>Channel 0 Voltage High Value |
| 15:12          | /          | /           | /                                                |
| 11:0           | R/W        | 0x400       | CH0_CMP_LOW_DATA<br>Channel 0 Voltage Low Value  |

#### 9.8.6.15 0x0080 GPADC CH0 Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: GP_CHO_DATA    |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:12          | /          | /           | /                             |
| 11:0           | R          | 0x000       | GP_CHO_DATA<br>Channel 0 Data |



## 9.9 TPADC

### 9.9.1 Overview

The Touch Panel ADC (TPADC) is a 4-wire resistive touch screen controller, including a 12-bit SAR type A/D converter.

The TPADC has the following features:

- 12 bit SAR type A/D converter
- Configurable sample frequency up to 1 MHz
- One 32x12 FIFO for storing A/D conversion result
- Supports DMA slave interface
- Supports 4-wire resistive touch panel input detection
  - Supports pen down detection with programmable sensitivity
  - Supports single touch coordinate measurement
  - Supports dual touch detection
  - Supports touch pressure measurement with programmable threshold
  - Supports median and averaging filter for noise reduction
  - Supports X and Y coordinate exchange function
- Supports Aux ADC with up to 4 channels

### 9.9.2 Functional Description

#### 9.9.2.1 External Signals

The following table describes the external signals of the TPADC.

Table 9-30 TPADC External Signals

| Signal | Description          | Type |
|--------|----------------------|------|
| TP-X1  | Touch Panel X1 Input | AI   |
| TP-X2  | Touch Panel X2 Input | AI   |
| TP-Y1  | Touch Panel Y1 Input | AI   |
| TP-Y2  | Touch Panel Y2 Input | AI   |

### 9.9.2.2 Single-ended Mode and Differential Mode

The controller is a typical type of successive approximation ADC (SAR ADC) which contains a sample/hold, analog-to-digital conversion, serial data output functions.

The analog inputs ( $X_+$ ,  $X_-$ ,  $Y_+$ ,  $Y_-$ ) enter the ADC through the control register, the ADC can work in single-ended or differential mode. Selecting Aux ADC should work in single-ended mode; for a touch screen application, it works in a differential mode, which can effectively eliminate the impact on conversion accuracy caused by the parasitic resistance of the driver switch and external interference.

Figure 9-73 shows TPADC Single-Ended Mode for the measurement of Aux, using the 1.8 V reference source as the ADC reference voltage.

**Figure 9-73 TPADC Single-Ended Mode for AUX ADC**



Figure 9-74 shows TPADC differential mode for the measurement of X/Y/Z coordinate of Touch Panel. The advantage of differential mode: +REF and -REF can directly input to the  $Y_+$  and  $Y_-$ (or  $X_+$  and  $X_-$ ), which can eliminate the measurement error of  $X_+/X_-$ (or  $Y_+/Y_-$ ) because of the switch on resistance. The disadvantage is that: both the sample or conversion process, the driver will need to be enabled. Compared with single-ended mode, the power consumption increases.

**Figure 9-74 TPADC Differential Mode for Touch Panel**

### 9.9.2.3 Single Touch Measurement

The following figure shows the operation principle of the single touch X-Coordinate measurement.

**Figure 9-75 Single Touch X-Coordinate Measurement for Touch Panel**

For an X coordinate measurement, the X+ pin is internally switched to VCC\_REF and X- to GND. The X plate becomes a potential divider, and the voltage at the point of contact is proportional to its X co-ordinate. This voltage is measured on the Y+, which carries no current (hence there is no voltage drop in RY+ or RY-). Due to the ratio metric measurement method, the supply voltage does not affect measurement accuracy. The voltage

references VREF+ and VREF- are taken from after the matrix switches, so that any voltage drop in these switches has no effect on the ADC measurement.

Y coordinate measurements are similar to X coordinate measurements, with the X and Y plates interchanged.

#### 9.9.2.4 Dual Touch Measurement

In single touch mode, it only needs to test X+ and Y+ signals. But in dual touch mode, it needs to test X+, X-, Y+, and Y- signals. The following figure shows the operation principle of dual touch detection for touch panel.

Figure 9-76 Dual Touch Detection for Touch Panel



For X coordinates measurement, the X+ pin is internally switched to 3 V and X- to GND. The controller needs to test Y+ and Y-, Y coordinates measurement is similar. And record  $\Delta X = |X_+ - X_-|$ ,  $\Delta Y = |Y_+ - Y_-|$ . In practice, we can set a threshold. If  $\Delta X$  or  $\Delta Y$  is greater than the threshold, we consider it as a dual touch, otherwise as a single touch.

#### 9.9.2.5 Touch Pressure Measurement

The pressure applied to the touch screen by a pen or finger to filter unavailable can also be measured by the controller using some simple calculations. The contact resistance between the X and Y plates is measured, which provides a good indication of the size of the depressed area and the applied pressure. The area of the touch spot  $t$  is proportional to the size of the object touching it. And the value of this resistance ( $R_{touch}$ ) can be calculated using two different methods.

**Figure 9-77 Touch Pressure Measurement for Touch Panel****(1) First Method**

The first method requires the user to know the total resistance of the X plate tablet ( $R_{XPLATE}$ ). Three touch screen conversions are required: measurement of the X position,  $X_{POSITION}(Y+ \text{ input})$ ; measurement of the  $X+$  input with the excitation voltage applied to  $Y+$  and  $X-$  ( $Z1$  measurement); and measurement of the  $Y-$  input with the excitation voltage applied to  $Y+$  and  $X-$  ( $Z2$  measurement). These three measurements are illustrated in following Figure. The controller have two special ADC channel settings to configure the X and Y switches for the  $Z1$  and  $Z2$  measurements and store the results in the  $Z1$  and  $Z2$  result registers. The touch resistance ( $R_{TOUCH}$ ) can then be calculated using the following equation.

$$R_{TOUCH} = (R_{XPLATE}) \times (X_{POSITION}/4096) \times [(Z2/Z1) - 1]$$

**(2) Second Method**

The second method requires the user to know the resistance of the X-plate and Y-plate tablets. Three touch screen conversions are required: a measurement of the X position ( $X_{POSITION}$ ), the Y position ( $Y_{POSITION}$ ), and the  $Z1$  position. The following equation also calculates the touch resistance ( $R_{TOUCH}$ ).

$$R_{TOUCH} = R_{XPLATE} \times (X_{POSITION}/4096) \times [(4096/Z1) - 1] - R_{YPLATE} \times [1 - (Y_{POSITION}/4096)]$$

**9.9.2.6 Pen Down Detection**

Pen down detection is used as an interrupt to the host. RIRQ is an internal pull-up resistor with a programmable value from 6 kΩ to 96 kΩ (default 48 kΩ).

**Figure 9-78 Pen Down Detection for Touch Panel**

The pen down IRQ output is pulled high by an internal pull-up. In the pen down detection, the Y- driver is enabled and connected to GND, and the pen down IRQ output is connected to the X+ input. When the panel is touched, the X+ input is pulled to ground through the touch screen, and the pen down IRQ output goes low because of the current path through the panel to GND, initiating an interrupt to the processor.

During the measurement cycle for X-, Y-, and Z-position, the X+ input is disconnected from the pen down IRQ pull-down transistor to eliminate any pull-up resistor leakage current from flowing through the touch screen, thus causing no errors.

#### 9.9.2.7 Median and Averaging Filter

Touch screens are composed of two resistive layers, normally placed over an LCD screen. Because these layers are in close proximity to the LCD screen, noise can be coupled from the screen onto these resistive layers, causing errors in the touch screen positional measurements.

The controller contain a filtering block to process the data and discard the spurious noise before sending the information to the host. The purpose of this block is not only the suppression of noise; the on-chip filtering also greatly reduces the host processing loading.

The processing function consists of two filters that are applied to the converted results: the median filter and the averaging filter. The median filter suppresses the isolated out-of-range noise and sets the number of measurements to be taken. These measurements are arranged in a temporary array, where the first value is the smallest measurement and the last value is the largest measurement. Then the averaging filter size determines the number of values to average. There are four choices which is configured by TP\_CTRL3 register (bit 1 and bit 0) to filtrate the ADC sampling data.

**Figure 9-79 Median and Averaging Filter Size**

| <b>Bit1</b> | <b>Bit0</b> | <b>Averaging Filter Size</b> | <b>Median Filter Size</b> |
|-------------|-------------|------------------------------|---------------------------|
| 0           | 0           | 2                            | 4                         |

| Bit1 | Bit0 | Averaging Filter Size | Median Filter Size |
|------|------|-----------------------|--------------------|
| 0    | 1    | 3                     | 5                  |
| 1    | 0    | 4                     | 8                  |
| 1    | 1    | 8                     | 16                 |

Example: In this example, the bit[1:0] of TP\_CTRL\_REG3 is configured as 2'b11. So the median filter has a window size of 16. This means that 16 measurements are taken and arranged in descending order in a temporary array. The averaging window size in this example is 8. The output is the average of the middle eight values of the 16 measurements taken with the median filter.

**Figure 9-80 Median and Averaging Filter Example**



### 9.9.3 Register List

| Module Name | Base Address |
|-------------|--------------|
| TPADC       | 0x02009C00   |

| Register Name        | Offset | Description                        |
|----------------------|--------|------------------------------------|
| TP_CTRL_REG0         | 0x0000 | TP Control Register 0              |
| TP_CTRL_REG1         | 0x0004 | TP Control Register 1              |
| TP_CTRL_REG2         | 0x0008 | TP Control Register 2              |
| TP_CTRL_REG3         | 0x000C | TP Control Register 3              |
| TP_INT_FIFO_CTRL_REG | 0x0010 | TP Interrupt FIFO Control Register |
| TP_INT_FIFO_STAT_REG | 0x0014 | TP Interrupt FIFO Status Register  |

| Register Name    | Offset | Description                  |
|------------------|--------|------------------------------|
| TP_CALI_DATA_REG | 0x001C | TP Calibration Data Register |
| TP_DATA_REG      | 0x0024 | TP Data Register             |

### 9.9.4 Register Description

#### 9.9.4.1 0x0000 TP Control Register 0 (Default Value:0x0F80\_0000)

| Offset: 0x0000 |            |             | Register Name: TP_CTRL0                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 31:24          | R/W        | 0xF         | <p>ADC_FIRST_DLY<br/>ADC First Convert Delay Time (T_FCDT) Setting<br/>Based on ADC first convert delay mode select (Bit 23)<br/><math>T_{FCDT} = \text{ADC\_FIRST\_DLY} * \text{ADC\_FIRST\_DLY\_MODE}</math></p> |
| 23             | R/W        | 0x1         | <p>ADC_FIRST_DLY_MODE<br/>ADC First Convert Delay Mode Select<br/>0: CLK_IN/16<br/>1: CLK_IN/16*256</p>                                                                                                            |
| 22             | /          | /           | /                                                                                                                                                                                                                  |
| 21:20          | R/W        | 0x0         | <p>ADC_CLK_DIVIDER<br/>ADC Clock Divider (CLK_IN)<br/>00: CLK/2<br/>01: CLK/3<br/>10: CLK/6<br/>11: CLK/1</p>                                                                                                      |
| 19:16          | R/W        | 0x0         | <p>FS_DIV<br/>ADC Sample Frequency Divider<br/>0000: CLK_IN/2<sup>(20-0)</sup><br/>0001: CLK_IN/2<sup>(20-1)</sup><br/>0010: CLK_IN/2<sup>(20-2)</sup><br/>....<br/>1111: CLK_IN/2<sup>(20-15)</sup></p>           |
| 15:0           | R/W        | 0x0         | <p>TACQ<br/>Touch panel ADC acquire time<br/>CLK_IN/(16*(N+1))</p>                                                                                                                                                 |

## 9.9.4.2 0x0004 TP Control Register 1 (Default Value:0x0000\_0101)

| Offset: 0x0004 |            |             | Register Name: TP_CTRL_REG1                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
| 31:20          | /          | /           | /                                                                                                                              |
| 19:12          | R/W        | 0x0         | STYLUS_UP_DEBOUNCE<br>Stylus Up De-bounce Time Setting<br>0x00: 0<br>....<br>0xFF: 2N*(CLK_IN/16*256)                          |
| 11:10          | /          | /           | /                                                                                                                              |
| 9              | R/W        | 0x0         | STYLUS_UP_DEBOUCE_EN<br>Stylus Up Debounce Function Select<br>0: Disable<br>1: Enable                                          |
| 8              | R/W        | 0x1         | CHOPPER_EN<br>T-sensor Chopping Enable<br>0: Disable<br>1: Enable<br>This field is not used when there is no T-sensor in TPADC |
| 7              | R/W        | 0x0         | TOUCH_PAN_CALI_EN<br>Touch Panel Calibration<br>1: Start calibration, it is cleared to 0 after calibration                     |
| 6              | R/W        | 0x0         | TP_DUAL_EN<br>Touch Panel Double Point Enable<br>0: Disable<br>1: Enable                                                       |
| 5              | R/W        | 0x0         | TP_EN.<br>TP Function Enable<br>0: Disable<br>1: Enable                                                                        |
| 4              | R/W        | 0x0         | TP_MODE_SELECT.<br>Touch Panel Mode and Auxiliary ADC Mode Select<br>0: TP<br>1: Auxiliary ADC                                 |

| Offset: 0x0004 |            |             | Register Name: TP_CTRL_REG1                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 3              | R/W        | 0x0         | ADC_CHAN3_SELECT<br>Analog Input Channel 3 Select<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | ADC_CHAN2_SELECT<br>Analog Input Channel 2 Select<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | ADC_CHAN1_SELECT<br>Analog Input Channel 1 Select<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x1         | ADC_CHAN0_SELECT<br>Analog Input Channel 0 Select<br>0: Disable<br>1: Enable |

CHAN0~3 can be selected at the same time. If N channel is selected, each channel has 1/N full speed of the ADC. If only one channel is selected, it has the full conversion rate. CHAN0~3 correspond to TP\_YN, TP\_YP, TP\_XN, TP\_XP.

#### 9.9.4.3 0x0008 TP Control Register 2 (Default Value:0x8000\_0FFF)

| Offset: 0x0008 |            |             | Register Name: TP_CTRL_REG2                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:28          | R/W        | 0x8         | TP_SENSITIVE_ADJUST<br>Internal Pull-up Resistor Control<br>0000: least sensitive<br>.....<br>1111: most sensitive<br>This field is used to adjust sensitivity of pen down detection. |

| Offset: 0x0008 |            |             | Register Name: TP_CTRL_REG2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 27:26          | R/W        | 0x0         | <p>TP_FIFO_MODE_SELECT<br/>TP FIFO Access Data Mode Select<br/>00: FIFO store X1,Y1 data for single touch no pressure mode<br/>01: FIFO store X1,Y1, <math>\Delta</math>X, <math>\Delta</math>Y data for dual touch no pressure mode<br/>10: FIFO store X1,Y1, X2,Y2 data for dual touch no pressure mode<br/>11: FIFO store X1,Y1, X2,Y2,Z1,Z2 data for dual touch and pressure mode</p> <p>The ADC output data in single touch mode can store in FIFO with TP_FIFO_MODE_SELECT configured as 01,10,11. But the data <math>\Delta</math>X, <math>\Delta</math>Y is theoretically equal to X1,Y1, and X2,Y2 is equal to 0.</p> <p>When PRE_MEA_EN is set and TP_FIFO_MODE_SELECT is not configured as 2'b11, X and Y data will not be stored unless <math>x1*(z2-z1)/z1 &lt; PRE_MEA_THRE_CNT</math>.</p> <p>Z data will always be zero when TP_FIFO_MODE_SELECT is configured as 2'b11 but PRE_MEA_EN is not set.</p> |
| 25             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 24             | R/W        | 0x0         | <p>PRE_MEA_EN<br/>TP Pressure Measurement Enable Control<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 23:0           | R/W        | 0xFFFF      | <p>PRE_MEA_THRE_CNT<br/>TP Pressure Measurement Threshold Control<br/>0x000000:least sensitive<br/>0xFFFFFFF: most sensitive</p> <p>This field is used to adjust sensitivity of touch.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 9.9.4.4 0x000C TP Control Register 3 (Default Value:0x0000\_0001)

| Offset: 0x000C |            |             | Register Name: TP_CTRL_REG3 |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:3           | /          | /           | /                           |

| Offset: 0x000C |            |             | Register Name: TP_CTRL_REG3                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 2              | R/W        | 0x0         | FILTER_EN<br>Filter Enable<br>0: Disable<br>1: Enable                   |
| 1:0            | R/W        | 0x1         | FILTER_TYPE<br>Filter Type<br>00: 4/2<br>01: 5/3<br>10: 8/4<br>11: 16/8 |

#### 9.9.4.5 0x0010 TP Interrupt& FIFO Control Register (Default Value:0x0000\_0F00)

| Offset: 0x0010 |            |             | Register Name: TP_INT_FIFO_CTRL_REG                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                               |
| 31:18          | /          | /           | /                                                                                                                                                         |
| 17             | R/W        | 0x0         | TP_OVERRUN_IRQ_EN<br>TP FIFO Overrun IRQ Enable<br>0: Disable<br>1: Enable                                                                                |
| 16             | R/W        | 0x0         | TP_DATA_IRQ_EN<br>TP FIFO Data Available IRQ Enable<br>0: Disable<br>1: Enable                                                                            |
| 15:14          | /          | /           | /                                                                                                                                                         |
| 13             | R/W        | 0x0         | TP_DATA_XY_CHANGE<br>TP FIFO X,Y Data Interchange Function Select<br>0: Disable<br>1: Enable                                                              |
| 12:8           | R/W        | 0xF         | TP_FIFO_TRIG_LEVEL<br>TP FIFO Data Available Trigger Level<br>Interrupt and DMA request trigger level for TP or Auxiliary ADC<br>Trigger Level = TXTL + 1 |

| Offset: 0x0010 |            |             | Register Name: TP_INT_FIFO_CTRL_REG                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 7              | R/W        | 0x0         | TP_DATA_DRQ_EN<br>TP FIFO Data Available DRQ Enable<br>0: Disable<br>1: Enable                |
| 6:5            | /          | /           | /                                                                                             |
| 4              | R/WAC      | 0x0         | TP_FIFO_FLUSH<br>TP FIFO Flush<br>Write '1' to flush TX FIFO, self clear to '0'               |
| 3:2            | /          | /           | /                                                                                             |
| 1              | R/W        | 0x0         | TP_UP_IRQ_EN<br>Touch Panel Last Touch (Stylus Up) IRQ Enable<br>0: Disable<br>1: Enable      |
| 0              | R/W        | 0x0         | TP_DOWN_IRQ_EN<br>Touch Panel First Touch (Stylus Down) IRQ Enable<br>0: Disable<br>1: Enable |

#### 9.9.4.6 0x0014 TP Interrupt& FIFO Status Register (Default Value:0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: TP_INT_FIFO_STAT_REG                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 31:18          | /          | /           | /                                                                                                                                                                                                 |
| 17             | R/W1C      | 0x0         | FIFO_OVERRUN_PENDING<br>TP FIFO Overrun IRQ pending<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if interrupt condition fails. |
| 16             | R/W1C      | 0x0         | FIFO_DATA_PENDING<br>TP FIFO Data Available Pending Bit<br>0: NO Pending IRQ<br>1: FIFO Available Pending IRQ<br>Write '1' to clear this interrupt or automatically clear if FIFO flushed.        |

| Offset: 0x0014 |            |             | Register Name: TP_INT_FIFO_STAT_REG                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 15:14          | /          | /           | /                                                                                                                                                                                              |
| 13:8           | R          | 0x0         | RXA_CNT<br>TP FIFO Available Sample Word Counter                                                                                                                                               |
| 7:3            | /          | /           | /                                                                                                                                                                                              |
| 2              | R          | 0x0         | TP_IDLE_FLG<br>Touch Panel Idle Flag<br>0: idle<br>1: not idle                                                                                                                                 |
| 1              | R/W1C      | 0x0         | TP_UP_PENDING<br>Touch Panel Last Touch (Stylus Up) IRQ Pending bit<br>0: No IRQ<br>1: IRQ<br>Writing 1 to the bit clears it and its corresponding interrupt if the interrupt is enabled.      |
| 0              | R/W1C      | 0x0         | TP_DOWN_PENDING<br>Touch Panel First Touch (Stylus Down) IRQ Pending bit<br>0: No IRQ<br>1: IRQ<br>Writing 1 to the bit clears it and its corresponding interrupt if the interrupt is enabled. |

#### 9.9.4.7 0x001C TP Calibration Data Register (Default Value:0x0000\_0800)

| Offset: 0x001C |            |             | Register Name: TP_CALI_DATA_REG                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:12          | /          | /           | /                                                                                    |
| 11:0           | R/W        | 0x800       | TP_CDAT<br>TP Common Data<br>It is used to adjust the tolerance of the internal ADC. |

#### 9.9.4.8 0x0024 TP Data Register (Default Value:0x0000\_0000)

In touch panel mode, the data stored in this register bases on TP\_FIFO\_MODE\_SELECT. In Auxiliary ADC mode, the data stored in this register bases on ADC\_CHAN\_SELECT. If four channels are enabled, FIFO will access the input data in successive turn (ADC\_CHAN0 -> ADC\_CHAN1 -> ADC\_CHAN2 -> ADC\_CHAN3). If only two or three

channels are selected, such as ADC\_CHAN0 and ADC\_CHAN3, firstly ADC\_CHAN0 input data is accessed, then ADC\_CHAN3 input data.

| Offset: 0x0024 |            |             | Register Name: TP_DATA_REG                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                    |
| 31:12          | /          | /           | /                                                                                              |
| 11:0           | R          | 0x0         | TP_DATA<br>Touch Panel X,Y data or Auxiliary analogy input data converted by the internal ADC. |

## 9.10 PWM

### 9.10.1 Overview

The Pulse Width Modulation (PWM) module can output the configurable PWM waveforms and measure the external input waveforms.

The PWM has the following features:

- Supports 8 independent PWM channels (PWM0 to PWM7)
  - Supports PWM continuous mode output
  - Supports PWM pulse mode output, and the pulse number is configurable
  - Output frequency range: 0 to 24 MHz or 100 MHz
  - Various duty-cycle: 0% to 100%
  - Minimum resolution: 1/65536
- Supports 4 complementary pairs output
  - PWM01 pair (PWM0 + PWM1), PWM23 pair (PWM2 + PWM3), PWM45 pair (PWM4 + PWM5), PWM67 pair (PWM6 + PWM7)
  - Supports dead-zone generator, and the dead-zone time is configurable
- Supports 4 group of PWM channel output for controlling stepping motors
  - Supports any plural channels to form a group, and output the same duty-cycle pulse
  - In group mode, the relative phase of the output waveform for each channel is configurable
- Supports 8 channels capture input
  - Supports rising edge detection and falling edge detection for input waveform pulse
  - Supports pulse-width measurement for input waveform pulse

### 9.10.2 Block Diagram

The PWM includes multi PWM channels. Each channel can generate different PWM waveform by the independent counter and duty-ratio configuration register. Each PWM pair shares one group of clock and dead-zone generator to generate PWM waveform.

Figure 9-81 PWM Block Diagram



Each PWM pair consists of 1 clock module, 2 timer logic module, and 1 programmable dead-zone generator.

### 9.10.3 Functional Description

#### 9.10.3.1 External Signals

The following table describes the external signals of the PWM.

Table 9-31 PWM External Signals

| Signal | Description                 | Type |
|--------|-----------------------------|------|
| PWM0   | Pulse Width Module Channel0 | I/O  |
| PWM1   | Pulse Width Module Channel1 | I/O  |
| PWM2   | Pulse Width Module Channel2 | I/O  |
| PWM3   | Pulse Width Module Channel3 | I/O  |
| PWM4   | Pulse Width Module Channel4 | I/O  |
| PWM5   | Pulse Width Module Channel5 | I/O  |
| PWM6   | Pulse Width Module Channel6 | I/O  |
| PWM7   | Pulse Width Module Channel7 | I/O  |

#### 9.10.3.2 Typical Application

- Suitable for display device, such as LCD

- Suitable for electric motor control

### 9.10.3.3 Clock Controller

Using PWM01 as an example. The other PWM pairs are the same as PWM01.

**Figure 9-82 PWM01 Clock Controller Diagram**



The clock controller of each PWM pair includes clock source select ([PWM01\\_CLK\\_SRC](#)), 1~256 scaler ([PWM01\\_CLK\\_DIV\\_M](#)). Each PWM channel has the secondary frequency division ([PWM\\_PRESCAL\\_K](#)), clock source bypass ([PWMx\\_CLK\\_BYPASS](#)) and clock switch ([PWMx\\_CLK\\_GATING](#)).

The clock sources have HOSC and APBO. The HOSC comes from the external high-frequency oscillator; the APBO is APBO bus clock.

The bypass function of the clock source is that the clock source directly accesses PWM output, the PWM output waveform is the waveform of the clock controller output. The BYPASS gridlines in the above figure indicate the bypass function of the clock source, see Figure 9-83 for the details about implement. At last, the output clock of the clock controller is sent to the PWM logic module.

### 9.10.3.4 PWM Output

Taking PWM01 as an example, Figure 9-83 indicates the PWM01 output logic diagram. The logic diagrams of other PWM pairs are the same as PWM01.

The timer logic module of PWM consists of one 16-bit up-counter ([PCNTR](#)) and three 16-bit parameters ([PWM\\_ENTIRE\\_CYCLE](#), [PWM\\_ACT\\_CYCLE](#), [PWM\\_COUNTER\\_START](#)). The [PWM\\_ENTIRE\\_CYCLE](#) is used to

control the PWM cycle, the PWM\_ACT\_CYCLE is used to control the duty-cycle, the PWM\_COUNTER\_START is used to control the output phase (multi-channel synchronization work requirements).

The PWM\_ENTIRE\_CYCLE and the PWM\_ACT\_CYCLE support the cache load, after PWM output is enabled, the register values of the PWM\_ENTIRE\_CYCLE and the PWM\_ACT\_CYCLE can be changed anytime, the changed value caches into the cache register. When the PCNTR counter outputs a period of PWM waveform, the value of the cache register can be updated for the PCNTR control. The purpose of the cache load is to avoid the unstable PWM output waveform with the burred feature when updating the values of the PWM\_ENTIRE\_CYCLE and PWM\_ACT\_CYCLE.

The PWM supports cycle and pulse waveform output.

**Cycle mode:** The PWM outputs the setting PWM waveform continually, that is, the output waveform is a continuous PWM square wave.

**Pulse mode:** After setting the PWM\_PUL\_NUM parameter, the PWM outputs (PWM\_PULNUM+1) periods of PWM waveform, that is, the waveform with several pulses are output.

Figure 9-83 PWM01 Output Logic Module Diagram



### 9.10.3.5 Up-Counter and Comparator

The period, duty-cycle, and phase of PWM output waveform are decided by the PCNTR, PWM\_ENTIRE\_CYCLE, PWM\_ACT\_CYCLE, and PWM\_COUNTER\_START. The rules are as follows.

- $\text{PCNTR} = (\text{PCNTR} == \text{PWM\_ENTIRE\_CYCLE}) ? 0 : \text{PCNTR} + 1$
- PCNTR starts to count by PWM\_COUNTER\_START, the counter of a PWM period is (PWM\_ENTIRE\_CYCLE+1).
- $\text{PCNTR} > (\text{PWM\_ENTIRE\_CYCLE} - \text{PWM\_ACT\_CYCLE})$ , output “active state”

- $\text{PCNTR} \leq (\text{PWM\_ENTIRE\_CYCLE} - \text{PWM\_ACT\_CYCLE})$ , output “~ (active state)”

#### Active state of PWM0 channel is high level (PCR0. PWM\_ACT\_STA = 1)

When  $\text{PCNTR} > (\text{PPR0. PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 1 (high level).

When  $\text{PCNTR} \leq (\text{PPR0. PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 0 (low level).

The formula of the output period and the duty-cycle for PWM are as follows.

$$T_{\text{period}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1)$$

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * \text{PPR0.PWM\_ACT\_CYCLE}$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1 - \text{PPR0.PWM\_ACT\_CYCLE})$$

$$\text{Duty-cycle} = (\text{high level time}) / (\text{1 period time}) = T_{\text{high-level}} / T_{\text{period}}$$

**Figure 9-84 PWM0 High Level Active State**



#### Active state of PWM0 channel is low level (PCR0. PWM\_ACT\_STA = 0)

When  $\text{PCNTR} > (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 0.

When  $\text{PCNTR} \leq (\text{PPR0.PWM\_ENTIRE\_CYCLE} - \text{PPR0.PWM\_ACT\_CYCLE})$ , then PWM0 outputs 1.

The formula of the output period and the duty-cycle for PWM are as follows.

$$T_{\text{period}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1)$$

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * (\text{PPR0.PWM\_ENTIRE\_CYCLE} + 1 - \text{PPR0.PWM\_ACT\_CYCLE})$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PREScale\_K})^{-1} * \text{PPR0.PWM\_ACT\_CYCLE}$$

$$\text{Duty-cycle} = (\text{low level time}) / (\text{1 period time}) = T_{\text{low-level}} / T_{\text{period}}$$

**Figure 9-85 PWM0 Low Level Active State**

The counter of PCNTR starts from 0 by default, it can output the pulse control of the waveform by setting [PWM\\_COUNTER\\_START](#). The figure is as follows.

**Figure 9-86 Phase of PWM0 High Level Active State**

#### 9.10.3.6 Pulse Mode and Cycle Mode

The PWM output supports pulse mode and cycle mode. PWM in pulse mode outputs one pulse waveform, but PWM in cycle mode outputs continuous waveform. Figure 9-87 shows the PWM output waveform in pulse mode and cycle mode.

Figure 9-87 PWM0 Output Waveform in Pulse Mode and Cycle Mode



Each channel of the PWM module supports the PWM output of pulse mode and cycle mode, the active state of the PWM output waveform can be programmed to control.

When PCR0[PWM\_MODE] is 0, the PWMO outputs in cycle mode. When PCR0[PWM\_MODE] is 1, the PWMO outputs in pulse mode.

Specifically, in pulse mode, after the PWMO channel enabled, PCR0[PWM\_PUL\_START] needs to be set to 1 when the PWMO needs to output pulse waveform, after completed the output, PCR0[PWM\_PUL\_START] can be cleared to 0 by hardware. The next setting 1 can be operated after PCR0[PWM\_PUL\_START] is cleared.

#### 9.10.3.7 Complementary Pair Output

Every PWM pair supports complementary pair output and PWM pair with dead-time. Figure 9-88 shows the complementary pair output of PWM01.

**Figure 9-88 PWM01 Complementary Pair Output**

The complementary pair output needs to satisfy the following conditions:

- PWM0 and PWM1 have the same clock divider, frequency, duty-cycle, and phase
- PWM0 and PWM1 have an opposite active state
- Enable the clock gating of PWM0 and PWM1 at the same time
- Enable the waveform output of PWM0 and PWM1 at the same time

#### 9.10.3.8 Dead-time Generator

Every PWM pair has a programmable dead-time generator. When the dead-time function of the PWM pair enabled, the PWM01 output waveform is decided by PWM timer logic and DeadZone Generator. Figure 9-89 shows the output waveform.

Figure 9-89 Dead-time Output Waveform



The PWM waveform before the insertion of dead-time indicates a complementary waveform pair of non-inserted dead-time in Dead Zone Generator 01.

The PWM waveform after the insertion of dead-time indicates a non-complementary PWM waveform pair inserted dead-time in a complementary waveform pair of Dead Zone Generator 01. The PWM waveform pair at last outputs to PWM0 pin and PWM1 pin.

For the complementary pair of Dead Zone Generator 01, the principle of inserting dead-time is that to insert dead-time as soon as the rising edge came. If the high level time for mark② in the above figure is less than dead-time, then dead-time will override the high level. The setting of dead-time needs to consider the period and the duty-cycle of the output waveform. The dead-time formula is defined as follows:

$$\text{Dead-time} = (\text{PWM01_CLK} / \text{PWM0_PRESCALE_K})^{-1} * \text{PDZINTV01}$$

#### 9.10.3.9 PWM Group Mode

Taking PWM Group0 as an example. The same group of PWM channel is selected to work by PGR0.CS; the same PWM\_ENTIRE\_CYCLE, PWM\_ACT\_CYCLE are set by the same clock configuration; the different PWM\_COUNTER\_START can output PWM group signals with the same duty-cycle and the different phase.

Figure 9-90 Group 0~3 PWM Signal Output



### 9.10.3.10 Capture Input

Figure 9-91 PWM01 Capture Logic Module Diagram



Besides the timer logic module of every PWM channel generates PWM output, it can be used to capture the rising edge and the falling edge of the external clock. Using the PWM0 channel as an example, the PWM0 channel has one CFLR0 and one CRLR0 for capturing up-counter value on the falling edge and rising edge, respectively. You can calculate the period of the external clock by CFLR0 and CRLR0.

$$T_{\text{high-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CRLR0}$$

$$T_{\text{low-level}} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CFLR0}$$

$$T_{\text{period}} = T_{\text{high-level}} + T_{\text{low-level}}$$

**Figure 9-92 PWM0 Channel Capture Timing**



When the capture input function of the PWM0 channel is enabled, the PCNTR of the PWM0 channel starts to work.

When the timer logic module of PWM0 captures a rising edge, the current value of the up-counter is locked to CRLR0 and CCR0[CRLF] is set to 1. If CRIE0 is 1, then CRISO is set to 1, the PWM0 channel sends interrupt requests, and the up-counter is loaded to 0 and continues to count. If CRIE0 is 0, the timer logic module of PWM0 captures a rising edge, CRISO cannot be set to 1, the up-counter is not loaded to 0.

When the timer logic module of PWM0 captures one falling edge, the current value of PCNTR is locked to CFLR0 and CCR0[CFLF] is set to 1. If CFIE0 is 1, then CFISO is set to 1, the PWM0 channel sends interrupt requests, and the up-counter is loaded to 0 and continues to count. If CFIE0 is 0, the timer logic module of PWM0 captures a falling edge, CFISO cannot be set to 1, the up-counter is not loaded to 0.

### 9.10.3.11 Interrupt

The PWM supports an interrupt generation when configuring the PWM channel to PWM output or capturing input.

For PWM output function, when the controller outputs one period of PWM waveform in cycle mode, the PIS of the corresponding PWM channel is set to 1; when the controller outputs (PWM\_PULNUM+1) periods of PWM waveform in pulse mode, the PIS of the corresponding PWM channel is set to 1.

**NOTE**

The PIS bit is set to 1 automatically by hardware and cleared by software.

For capturing input function, when the timer logic module of the capture channel0 captures rising edge, and CRIEO is 1, then CRISO is set to 1; when the timer logic module of the capture channel0 captures falling edge, and CFIEO is 1, then CFISO is set to 1.

## 9.10.4 Programming Guidelines

The following working mode takes PWM01 as an example, other PWM pairs and PWM01 are consistent.

### 9.10.4.1 Configuring Clock

- Step 1** PWM gating: When using PWM, write 1 to PCGR[PWMx\_CLK\_GATING].
- Step 2** PWM clock source select: Set PCCR01[PWM01\_CLK\_SRC] to select HOSC or APB0 clock.
- Step 3** PWM clock divider: Set PCCR01[PWM01\_CLK\_DIV\_M] to select different frequency division coefficient (1/2/4/8/16/32/64/128/256).
- Step 4** PWM clock bypass: Set PCGR[PWM\_CLK\_SRC\_BYPASS\_TO\_PWM] to 1, output the PWM clock after the secondary frequency division to the corresponding PWM output pin.
- Step 5** PWM internal clock configuration: Set PCR[PWM\_PRESCAL\_K] to select any frequency division coefficient from 1 to 256.

**NOTE**

For the channel of complementary output and group mode, firstly, set the same clock configurations (clock source selects APB0, clock division configures the same division factor); secondly, open clock gating at the same time; thirdly, configure PWM parameters; finally, enable PWM output at the same time to ensure each channel sync.

We suggest that the two channels of the same PWM pair cannot subject to two groups because of they have the same first level clock division and gating. If must allocate based on this way, the first level of clock division of the channel used by all groups needs to set to the same coefficient and open gating at the same time. And the total module needs to be reset when the group mode regroups.

#### 9.10.4.2 Configuring PWM

- Step 1** PWM mode: Set [PCR\[PWM\\_MODE\]](#) to select cycle mode or pulse mode, if pulse mode, [PCR\[PWM\\_PUL\\_NUM\]](#) needs to be configured.
- Step 2** PWM active level: Set [PCR\[PWM\\_ACT\\_STA\]](#) to select a low level or high level.
- Step 3** PWM duty-cycle: Configure [PPR\[PWM\\_ENTIRE\\_CYCLE\]](#) and [PPR\[PWM\\_ACT\\_CYCLE\]](#) after clock gating is opened.
- Step 4** PWM starting/stopping phase: Configure [PCNTR\[PWM\\_COUNTER\\_START\]](#) after the clock gating is enabled and before the PWM is enabled. You can verify whether the configuration was successful by reading back [PCNTR\[PWM\\_COUNTER\\_STATUS\]](#).
- Step 5** Enable PWM: Configure PER to select the corresponding PWM enable bit; when selecting pulse mode, [PCR\[PWM\\_PUL\\_START\]](#) needs to be enabled.

#### 9.10.4.3 Configuring Deadzone

- Step 1** Set initial value: set [C:\Users\zengjing\Downloads\ PWM01\\_Dead\\_Zone - Hlk49450444C:\Users\zengjing\Downloads\ PWM01\\_Dead\\_Zone - Hlk49450444\[PDZINTV01\]](#).
- Step 2** Enable Deadzone: set [C:\Users\zengjing\Downloads\ PWM01\\_Dead\\_Zone - Hlk49450444C:\Users\zengjing\Downloads\ PWM01\\_Dead\\_Zone - Hlk49450444\[PWM01\\_DZ\\_CN\]](#).

#### 9.10.4.4 Configuring Capture Input

- Step 1** Enable capture: Configure [CER](#) to enable the corresponding channel.
- Step 2** Capture mode: Configure [CCR\[CRLF\]](#) and [CCR\[CFLF\]](#) to select rising edge capture or falling edge capture, configure [CCR\[CAPINV\]](#) to select whether the input signal does reverse processing.

#### 9.10.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| PWM         | 0x02000C00   |

| Register Name | Offset | Description             |
|---------------|--------|-------------------------|
| PIER          | 0x0000 | PWM IRQ Enable Register |

| Register Name | Offset                             | Description                        |
|---------------|------------------------------------|------------------------------------|
| PISR          | 0x0004                             | PWM IRQ Status Register            |
| CIER          | 0x0010                             | Capture IRQ Enable Register        |
| CISR          | 0x0014                             | Capture IRQ Status Register        |
| PCCR01        | 0x0020                             | PWM01 Clock Configuration Register |
| PCCR23        | 0x0024                             | PWM23 Clock Configuration Register |
| PCCR45        | 0x0028                             | PWM45 Clock Configuration Register |
| PCCR67        | 0x002C                             | PWM67 Clock Configuration Register |
| PCGR          | 0x0040                             | PWM Clock Gating Register          |
| PDZCR01       | 0x0060                             | PWM01 Dead Zone Control Register   |
| PDZCR23       | 0x0064                             | PWM23 Dead Zone Control Register   |
| PDZCR45       | 0x0068                             | PWM45 Dead Zone Control Register   |
| PDZCR67       | 0x006C                             | PWM67 Dead Zone Control Register   |
| PER           | 0x0080                             | PWM Enable Register                |
| PGR0          | 0x0090                             | PWM Group0 Register                |
| PGR1          | 0x0094                             | PWM Group1 Register                |
| PGR2          | 0x0098                             | PWM Group2 Register                |
| PGR3          | 0x009C                             | PWM Group3 Register                |
| CER           | 0x00C0                             | Capture Enable Register            |
| PCR           | 0x0100+0x0000+N*0x0020<br>(N= 0~7) | PWM Control Register               |
| PPR           | 0x0100+0x0004+N*0x0020<br>(N= 0~7) | PWM Period Register                |
| PCNTR         | 0x0100+0x0008+N*0x0020<br>(N= 0~7) | PWM Count Register                 |
| PPCNTR        | 0x0100+0x000C+N*0x0020<br>(N= 0~7) | PWM Pulse Count Register           |
| CCR           | 0x0100+0x0010+N*0x0020<br>(N= 0~7) | Capture Control Register           |
| CRLR          | 0x0100+0x0014+N*0x0020<br>(N= 0~7) | Capture Rise Lock Register         |
| CFLR          | 0x0100+0x0018+N*0x0020<br>(N= 0~7) | Capture Fall Lock Register         |

### 9.10.6 Register Description

#### 9.10.6.1 0x0000 PWM IRQ Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0000 |            |             | Register Name: PIER                                                                                                |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                        |
| 31:20         | /          | /           | /                                                                                                                  |
| 19            | R/W        | 0x0         | PGIE3<br>PWM Group 3 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 18            | R/W        | 0x0         | PGIE2<br>PWM Group 2 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 17            | R/W        | 0x0         | PGIE1<br>PWM Group 1 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 16            | R/W        | 0x0         | PGIE0<br>PWM Group 0 Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 15:8          | /          | /           | /                                                                                                                  |
| 7             | R/W        | 0x0         | PCIE7<br>PWM Channel 7 Interrupt Enable<br>0: PWM Channel 7 Interrupt Disable<br>1: PWM Channel 7 Interrupt Enable |
| 6             | R/W        | 0x0         | PCIE6<br>PWM Channel 6 Interrupt Enable<br>0: PWM Channel 6 Interrupt Disable<br>1: PWM Channel 6 Interrupt Enable |
| 5             | R/W        | 0x0         | PCIE5<br>PWM Channel 5 Interrupt Enable<br>0: PWM Channel 5 Interrupt Disable<br>1: PWM Channel 5 Interrupt Enable |

| Offset:0x0000 |            |             | Register Name: PIER                                                                                                |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                        |
| 4             | R/W        | 0x0         | PCIE4<br>PWM Channel 4 Interrupt Enable<br>0: PWM Channel 4 Interrupt Disable<br>1: PWM Channel 4 Interrupt Enable |
| 3             | R/W        | 0x0         | PCIE3<br>PWM Channel 3 Interrupt Enable<br>0: PWM Channel 3 Interrupt Disable<br>1: PWM Channel 3 Interrupt Enable |
| 2             | R/W        | 0x0         | PCIE2<br>PWM Channel 2 Interrupt Enable<br>0: PWM Channel 2 Interrupt Disable<br>1: PWM Channel 2 Interrupt Enable |
| 1             | R/W        | 0x0         | PCIE1<br>PWM Channel 1 Interrupt Enable<br>0: PWM Channel 1 Interrupt Disable<br>1: PWM Channel 1 Interrupt Enable |
| 0             | R/W        | 0x0         | PCIE0<br>PWM Channel 0 Interrupt Enable<br>0: PWM Channel 0 Interrupt Disable<br>1: PWM Channel 0 Interrupt Enable |

#### 9.10.6.2 0x0004 PWM IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:0x0004 |            |             | Register Name: PISR                   |
|---------------|------------|-------------|---------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                           |
| 31:20         | /          | /           | /                                     |
| 19            | R/W1C      | 0x0         | PGIS3<br>PWM Group 3 Interrupt Status |
| 18            | R/W1C      | 0x0         | PGIS2<br>PWM Group 2 Interrupt Status |
| 17            | R/W1C      | 0x0         | PGIS1<br>PWM Group 1 Interrupt Status |
| 16            | R/W1C      | 0x0         | PGISO<br>PWM Group 0 Interrupt Status |

| Offset:0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                                                 |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                         |
| 15:8          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 7             | R/W1C      | 0x0         | PIS7<br>PWM Channel 7 Interrupt Status<br>When the PWM channel 7 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 7 interrupt is not pending.<br>Reads 1: PWM channel 7 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 7 interrupt status. |
| 6             | R/W1C      | 0x0         | PIS6<br>PWM Channel 6 Interrupt Status<br>When the PWM channel 6 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 6 interrupt is not pending.<br>Reads 1: PWM channel 6 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 6 interrupt status. |
| 5             | R/W1C      | 0x0         | PIS5<br>PWM Channel 5 Interrupt Status<br>When the PWM channel 5 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 5 interrupt is not pending.<br>Reads 1: PWM channel 5 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 5 interrupt status. |
| 4             | R/W1C      | 0x0         | PIS4<br>PWM Channel 4 Interrupt Status<br>When the PWM channel 4 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br>Reads 0: PWM channel 4 interrupt is not pending.<br>Reads 1: PWM channel 4 interrupt is pending.<br>Writes 0: No effect.<br>Writes 1: Clear PWM channel 4 interrupt status. |

| Offset:0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                                                              |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 3             | R/W1C      | 0x0         | <p>PIS3<br/>PWM Channel 3 Interrupt Status<br/>When the PWM channel 3 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br/>Reads 0: PWM channel 3 interrupt is not pending.<br/>Reads 1: PWM channel 3 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear PWM channel 3 interrupt status.</p> |
| 2             | R/W1C      | 0x0         | <p>PIS2<br/>PWM Channel 2 Interrupt Status<br/>When the PWM channel 2 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br/>Reads 0: PWM channel 2 interrupt is not pending.<br/>Reads 1: PWM channel 2 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear PWM channel 2 interrupt status.</p> |
| 1             | R/W1C      | 0x0         | <p>PIS1<br/>PWM Channel 1 Interrupt Status<br/>When the PWM channel 1 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br/>Reads 0: PWM channel 1 interrupt is not pending.<br/>Reads 1: PWM channel 1 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear PWM channel 1 interrupt status.</p> |
| 0             | R/W1C      | 0x0         | <p>PISO<br/>PWM Channel 0 Interrupt Status<br/>When the PWM channel 0 counter reaches the Entire Cycle Value, this bit is set 1 by hardware. Writing 1 to clear this bit.<br/>Reads 0: PWM channel 0 interrupt is not pending.<br/>Reads 1: PWM channel 0 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear PWM channel 0 interrupt status.</p> |

**9.10.6.3 0x0010 PWM Capture IRQ Enable Register (Default Value: 0x0000\_0000)**

| Offset:0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                        |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 31:16         | /          | /           | /                                                                                                                                                                                                                                          |
| 15            | R/W        | 0x0         | CFIE7<br>If the enable bit is set to 1, when the capture channel 7 captures falling edge, it generates a capture channel 7 pending.<br>0: Capture channel 7 fall lock interrupt disable<br>1: Capture channel 7 fall lock interrupt enable |
| 14            | R/W        | 0x0         | CRIE7<br>If the enable bit is set to 1, when the capture channel 7 captures rising edge, it generates a capture channel 7 pending.<br>0: Capture channel 7 rise lock interrupt disable<br>1: Capture channel 7 rise lock interrupt enable  |
| 13            | R/W        | 0x0         | CFIE6<br>If the enable bit is set to 1, when the capture channel 6 captures falling edge, it generates a capture channel 6 pending.<br>0: Capture channel 6 fall lock interrupt disable<br>1: Capture channel 6 fall lock interrupt enable |
| 12            | R/W        | 0x0         | CRIE6<br>If the enable bit is set to 1, when the capture channel 6 captures rising edge, it generates a capture channel 6 pending.<br>0: Capture channel 6 rise lock interrupt disable<br>1: Capture channel 6 rise lock interrupt enable  |
| 11            | R/W        | 0x0         | CFIE5<br>If the enable bit is set to 1, when the capture channel 5 captures falling edge, it generates a capture channel 5 pending.<br>0: Capture channel 5 fall lock interrupt disable<br>1: Capture channel 5 fall lock interrupt enable |
| 10            | R/W        | 0x0         | CRIE5<br>If the enable bit is set to 1, when the capture channel 5 captures rising edge, it generates a capture channel 5 pending.<br>0: Capture channel 5 rise lock interrupt disable<br>1: Capture channel 5 rise lock interrupt enable  |

| Offset:0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                        |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 9             | R/W        | 0x0         | CFIE4<br>If the enable bit is set to 1, when the capture channel 4 captures falling edge, it generates a capture channel 4 pending.<br>0: Capture channel 4 fall lock interrupt disable<br>1: Capture channel 4 fall lock interrupt enable |
| 8             | R/W        | 0x0         | CRIE4<br>If the enable bit is set to 1, when the capture channel 4 captures rising edge, it generates a capture channel 4 pending.<br>0: Capture channel 4 rise lock interrupt disable<br>1: Capture channel 4 rise lock interrupt enable  |
| 7             | R/W        | 0x0         | CFIE3<br>If the enable bit is set to 1, when the capture channel 3 captures falling edge, it generates a capture channel 3 pending.<br>0: Capture channel 3 fall lock interrupt disable<br>1: Capture channel 3 fall lock interrupt enable |
| 6             | R/W        | 0x0         | CRIE3<br>If the enable bit is set to 1, when the capture channel 3 captures rising edge, it generates a capture channel 3 pending.<br>0: Capture channel 3 rise lock interrupt disable<br>1: Capture channel 3 rise lock interrupt enable  |
| 5             | R/W        | 0x0         | CFIE2<br>If the enable bit is set to 1, when the capture channel 2 captures falling edge, it generates a capture channel 2 pending.<br>0: Capture channel 2 fall lock interrupt disable<br>1: Capture channel 2 fall lock interrupt enable |
| 4             | R/W        | 0x0         | CRIE2<br>If the enable bit is set to 1, when the capture channel 2 captures rising edge, it generates a capture channel 2 pending.<br>0: Capture channel 2 rise lock interrupt disable<br>1: Capture channel 2 rise lock interrupt enable  |
| 3             | R/W        | 0x0         | CFIE1<br>If the enable bit is set to 1, when the capture channel 1 captures falling edge, it generates a capture channel 1 pending.<br>0: Capture channel 1 fall lock interrupt disable<br>1: Capture channel 1 fall lock interrupt enable |

| Offset:0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                                        |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
| 2             | R/W        | 0x0         | <p>CRIE1</p> <p>If the enable bit is set to 1, when the capture channel 1 captures rising edge, it generates a capture channel 1 pending.</p> <p>0: Capture channel 1 rise lock interrupt disable<br/>1: Capture channel 1 rise lock interrupt enable</p>  |
| 1             | R/W        | 0x0         | <p>CFIE0</p> <p>If the enable bit is set to 1, when the capture channel 0 captures falling edge, it generates a capture channel 0 pending.</p> <p>0: Capture channel 0 fall lock interrupt disable<br/>1: Capture channel 0 fall lock interrupt enable</p> |
| 0             | R/W        | 0x0         | <p>CRIE0</p> <p>If the enable bit is set to 1, when the capture channel 0 captures rising edge, it generates a capture channel 0 pending.</p> <p>0: Capture channel 0 rise lock interrupt disable<br/>1: Capture channel 0 rise lock interrupt enable</p>  |

#### 9.10.6.4 0x0014 PWM Capture IRQ Status Register (Default Value: 0x0000\_0000)

| Offset:0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:18         | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15            | R/W1C      | 0x0         | <p>CFIS7</p> <p>Status of the capture channel 7 falling lock interrupt</p> <p>When the capture channel 7 captures falling edge, if the fall lock interrupt (<a href="#">CFIE7</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 7 interrupt is not pending.<br/>Reads 1: The capture channel 7 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear the status of the capture channel 7 interrupt.</p> |

| Offset:0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14            | R/W1C      | 0x0         | <p>CRIS7</p> <p>Status of the capture channel 7 rising lock interrupt</p> <p>When the capture channel 7 captures rising edge, if the rise lock interrupt (<a href="#">CRIE7</a>) is enabled, this bit is set to 1 by hardware. Write 1 to clear this bit.</p> <p>Reads 0: The capture channel 7 interrupt is not pending.</p> <p>Reads 1: The capture channel 7 interrupt is pending.</p> <p>Writes 0: No effect.</p> <p>Writes 1: Clear the status of the capture channel 7 interrupt.</p>      |
| 13            | R/W1C      | 0x0         | <p>CFIS6</p> <p>Status of the capture channel 6 falling lock interrupt</p> <p>When the capture channel 6 captures falling edge, if the fall lock interrupt (<a href="#">CFIE6</a>) is enabled, this bit is set to 1 by hardware. Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 6 interrupt is not pending.</p> <p>Reads 1: The capture channel 6 interrupt is pending.</p> <p>Writes 0: No effect.</p> <p>Writes 1: Clear the status of the capture channel 6 interrupt.</p>  |
| 12            | R/W1C      | 0x0         | <p>CRIS6</p> <p>Status of the capture channel 6 rising lock interrupt.</p> <p>When the capture channel 6 captures rising edge, if the rise lock interrupt (<a href="#">CRIE6</a>) is enabled, this bit is set to 1 by hardware. Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 6 interrupt is not pending.</p> <p>Reads 1: The capture channel 6 interrupt is pending.</p> <p>Writes 0: No effect.</p> <p>Writes 1: Clear the status of the capture channel 6 interrupt.</p>   |
| 11            | R/W1C      | 0x0         | <p>CFIS5</p> <p>Status of the capture channel 5 falling lock interrupt</p> <p>When the capturing channel 5 captures falling edge, if the fall lock interrupt (<a href="#">CFIE5</a>) is enabled, this bit is set to 1 by hardware. Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 5 interrupt is not pending.</p> <p>Reads 1: The capture channel 5 interrupt is pending.</p> <p>Writes 0: No effect.</p> <p>Reads 1: Clear the status of the capture channel 5 interrupt.</p> |

| Offset:0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10            | R/W1C      | 0x0         | <p>CRIS5<br/>Status of the capture channel 5 rising lock interrupt<br/>When the capture channel 5 captures rising edge, if the rise lock interrupt (<a href="#">CRIES5</a>) is enabled, this bit is set to 1 by hardware.<br/>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 5 interrupt is not pending.<br/>Reads 1: The capture channel 5 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear the status of the capture channel 5 interrupt.</p>        |
| 9             | R/W1C      | 0x0         | <p>CFIS4<br/>Status of the capture channel 4 falling lock interrupt<br/>When the capture channel 4 captures falling edge, if the fall lock interrupt (<a href="#">CFIE4</a>) is enabled, this bit is set to 1 by hardware.<br/>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 4 interrupt is not pending.<br/>Reads 1: The capture channel 4 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear the status of the capture channel 4 interrupt.</p>       |
| 8             | R/W1C      | 0x0         | <p>CRIS4<br/>Status of the capture channel 4 rising lock interrupt.<br/>When the capture channel 4 captures rising edge, if the rise lock interrupt (<a href="#">CRIE4</a>) is enabled, this bit is set to 1 by hardware.<br/>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 4 interrupt is not pending.<br/>Reads 1: The capture channel 4 interrupt is pending.<br/>Writes 0: No effect.<br/>Writes 1: Clear the status of the capture channel 4 interrupt status.</p> |
| 7             | R/W1C      | 0x0         | <p>CFIS3<br/>Status of the capture channel 3 falling lock interrupt.<br/>When the capture channel 3 captures falling edge, if the fall lock interrupt (<a href="#">CFIE3</a>) is enabled, this bit is set to 1 by hardware.<br/>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 3 interrupt is not pending.<br/>Reads 1: The capture channel 3 interrupt is pending.<br/>Writes 0: no effect.<br/>Writes 1: Clear the status of the capture channel 3 interrupt.</p>      |

| Offset:0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6             | R/W1C      | 0x0         | <p>CRIS3</p> <p>Status of the capture channel 3 rising lock interrupt</p> <p>When the capture channel 3 captures rising edge, if the rise lock interrupt (<a href="#">CRIE3</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 3 interrupt is not pending.</p> <p>Reads 1: The capture channel 3 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 3 interrupt.</p>   |
| 5             | R/W1C      | 0x0         | <p>CFIS2</p> <p>Status of the capture channel 2 falling lock interrupt</p> <p>When the capture channel 2 captures falling edge, if the fall lock interrupt (<a href="#">CFIE2</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 2 interrupt is not pending.</p> <p>Reads 1: The capture channel 2 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 2 interrupt.</p> |
| 4             | R/W1C      | 0x0         | <p>CRIS2</p> <p>Status of the capture channel 2 rising lock interrupt.</p> <p>When the capture channel 2 captures rising edge, if the rise lock interrupt (<a href="#">CRIE2</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 2 interrupt is not pending.</p> <p>Reads 1: The capture channel 2 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 2 interrupt.</p>  |
| 3             | R/W1C      | 0x0         | <p>CFIS1</p> <p>Status of the capture channel 1 falling lock interrupt</p> <p>When the capture channel 1 captures falling edge, if the fall lock interrupt (<a href="#">CFIE1</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 1 interrupt is not pending.</p> <p>Reads 1: The capture channel 1 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 1 interrupt.</p> |

| Offset:0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2             | R/W1C      | 0x0         | <p>CRIS1</p> <p>Status of the capture channel 1 rising lock interrupt.</p> <p>When the capture channel 1 captures rising edge, if the rise lock interrupt (<a href="#">CRIE1</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 1 interrupt is not pending.</p> <p>Reads 1: The capture channel 1 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 1 interrupt.</p>  |
| 1             | R/W1C      | 0x0         | <p>CFISO</p> <p>Status of the capture channel 0 falling lock interrupt</p> <p>When the capture channel 0 captures falling edge, if the fall lock interrupt (<a href="#">CFIE0</a>) is enabled, this bit is set to 1 by hardware.</p> <p>Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 0 interrupt is not pending.</p> <p>Reads 1: The capture channel 0 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 0 interrupt.</p> |
| 0             | R/W1C      | 0x0         | <p>CRISO</p> <p>Status of the capture channel 0 rising lock interrupt</p> <p>When the capture channel 0 captures rising edge, if the rise lock interrupt (<a href="#">CRIE0</a>) is enabled, this bit is set 1 by hardware. Writing 1 to clear this bit.</p> <p>Reads 0: The capture channel 0 interrupt is not pending.</p> <p>Reads 1: The capture channel 0 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>Writes 1: Clear the status of the capture channel 0 interrupt.</p>             |

#### 9.10.6.5 0x0020 PWM01 Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0020 |            |             | Register Name: PCCR01 |
|---------------|------------|-------------|-----------------------|
| Bit           | Read/Write | Default/Hex | Description           |
| 31:9          | /          | /           | /                     |

| Offset:0x0020 |            |             | Register Name: PCCR01                                                                                                                                                          |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 8:7           | R/W        | 0x0         | PWM01_CLK_SRC<br>Select PWM01 Clock Source<br>00: HOSC<br>01: APBO<br>Others: Reserved                                                                                         |
| 6:4           | /          | /           | /                                                                                                                                                                              |
| 3:0           | R/W        | 0x0         | PWM01_CLK_DIV_M<br>PWM01 Clock Divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>Others: Reserved |

#### 9.10.6.6 0x0024 PWM23 Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0024 |            |             | Register Name: PCCR23                                                                      |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                |
| 31:9          | /          | /           | /                                                                                          |
| 8:7           | R/W        | 0x0         | PWM23_CLK_SRC_SEL<br>Select PWM23 Clock Source<br>00: HOSC<br>01: APBO<br>Others: Reserved |
| 6:4           | /          | /           | /                                                                                          |

| Offset:0x0024 |            |             | Register Name: PCCR23                                                                                                                                                          |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 3:0           | R/W        | 0x0         | PWM23_CLK_DIV_M<br>PWM23 Clock Divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>Others: Reserved |

#### 9.10.6.7 0x0028 PWM45 Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x0028 |            |             | Register Name: PCCR45                                                                      |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                |
| 31:9          | /          | /           | /                                                                                          |
| 8:7           | R/W        | 0x0         | PWM45_CLK_SRC_SEL<br>Select PWM45 Clock Source<br>00: HOSC<br>01: APB0<br>Others: Reserved |
| 6:4           | /          | /           | /                                                                                          |

| Offset:0x0028 |            |             | Register Name: PCCR45                                                                                                                                                          |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                    |
| 3:0           | R/W        | 0x0         | PWM45_CLK_DIV_M<br>PWM45 Clock Divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>Others: Reserved |

#### 9.10.6.8 0x002C PWM67 Clock Configuration Register (Default Value: 0x0000\_0000)

| Offset:0x002C |            |             | Register Name: PCCR67                                                                      |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                |
| 31:9          | /          | /           | /                                                                                          |
| 8:7           | R/W        | 0x0         | PWM67_CLK_SRC_SEL<br>Select PWM67 Clock Source<br>00: HOSC<br>01: APB0<br>Others: Reserved |
| 6:4           | /          | /           | /                                                                                          |

| Offset:0x002C |            |             | Register Name: PCCR67                                                                                                                                                                               |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 3:0           | R/W        | 0x0         | <p>PWM67_CLK_DIV_M<br/>PWM67 Clock Divide M</p> <p>0000: /1<br/>0001: /2<br/>0010: /4<br/>0011: /8<br/>0100: /16<br/>0101: /32<br/>0110: /64<br/>0111: /128<br/>1000: /256<br/>Others: Reserved</p> |

#### 9.10.6.9 0x0040 PWM Clock Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31:24          | /          | /           | /                                                                                                                  |
| 23             | R/W        | 0x0         | <p>PWM7_CLK_BYPASS<br/>Bypass clock source (after pre-scale) to PWM7 output</p> <p>0: not bypass<br/>1: bypass</p> |
| 22             | R/W        | 0x0         | <p>PWM6_CLK_BYPASS<br/>Bypass clock source (after pre-scale) to PWM6 output</p> <p>0: not bypass<br/>1: bypass</p> |
| 21             | R/W        | 0x0         | <p>PWM5_CLK_BYPASS<br/>Bypass clock source (after pre-scale) to PWM5 output</p> <p>0: not bypass<br/>1: bypass</p> |
| 20             | R/W        | 0x0         | <p>PWM4_CLK_BYPASS<br/>Bypass clock source (after pre-scale) to PWM4 output</p> <p>0: not bypass<br/>1: bypass</p> |

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 19             | R/W        | 0x0         | PWM3_CLK_BYPASS<br>Bypass clock source (after pre-scale) to PWM3 output<br>0: not bypass<br>1: bypass |
| 18             | R/W        | 0x0         | PWM2_CLK_BYPASS<br>Bypass clock source (after pre-scale) to PWM2 output<br>0: not bypass<br>1: bypass |
| 17             | R/W        | 0x0         | PWM1_CLK_BYPASS<br>Bypass clock source (after pre-scale) to PWM1 output<br>0: not bypass<br>1: bypass |
| 16             | R/W        | 0x0         | PWM0_CLK_BYPASS<br>Bypass clock source (after pre-scale) to PWM0 output<br>0: not bypass<br>1: bypass |
| 15:8           | /          | /           | /                                                                                                     |
| 7              | R/W        | 0x0         | PWM7_CLK_GATING<br>Gating clock for PWM7<br>0: Mask<br>1: Pass                                        |
| 6              | R/W        | 0x0         | PWM6_CLK_GATING<br>Gating clock for PWM6<br>0: Mask<br>1: Pass                                        |
| 5              | R/W        | 0x0         | PWM5_CLK_GATING<br>Gating clock for PWM5<br>0: Mask<br>1: Pass                                        |
| 4              | R/W        | 0x0         | PWM4_CLK_GATING<br>Gating clock for PWM4<br>0: Mask<br>1: Pass                                        |

| Offset: 0x0040 |            |             | Register Name: PCGR                                            |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 3              | R/W        | 0x0         | PWM3_CLK_GATING<br>Gating clock for PWM3<br>0: Mask<br>1: Pass |
| 2              | R/W        | 0x0         | PWM2_CLK_GATING<br>Gating clock for PWM2<br>0: Mask<br>1: Pass |
| 1              | R/W        | 0x0         | PWM1_CLK_GATING<br>Gating clock for PWM1<br>0: Mask<br>1: Pass |
| 0              | R/W        | 0x0         | PWM0_CLK_GATING<br>Gating clock for PWM0<br>0: Mask<br>1: Pass |

#### 9.10.6.10 0x0060 PWM01 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Offset:0x0060 |            |             | Register Name: PDZCR01                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                          |
| 31:16         | /          | /           | /                                                                                    |
| 15:8          | R/W        | 0x0         | PWM01_DZ_INTV<br>PWM01 Dead Zone Interval Value                                      |
| 7:1           | /          | /           | /                                                                                    |
| 0             | R/W        | 0x0         | PWM01_DZ_EN<br>PWM01 Dead Zone Enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

**9.10.6.11 0x0064 PWM23 Dead Zone Control Register (Default Value: 0x0000\_0000)**

| Offset:0x0064 |            |             | Register Name: PDZCR23                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                          |
| 31:16         | /          | /           | /                                                                                    |
| 15:8          | R/W        | 0x0         | PWM23_DZ_INTV<br>PWM23 Dead Zone Interval Value                                      |
| 7:1           | /          | /           | /                                                                                    |
| 0             | R/W        | 0x0         | PWM23_DZ_EN<br>PWM23 Dead Zone Enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

**9.10.6.12 0x0068 PWM45 Dead Zone Control Register (Default Value: 0x0000\_0000)**

| Offset:0x0068 |            |             | Register Name: PDZCR45                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                          |
| 31:16         | /          | /           | /                                                                                    |
| 15:8          | R/W        | 0x0         | PWM45_DZ_INTV<br>PWM45 Dead Zone Interval Value                                      |
| 7:1           | /          | /           | /                                                                                    |
| 0             | R/W        | 0x0         | PWM45_DZ_EN<br>PWM45 Dead Zone Enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

**9.10.6.13 0x006C PWM67 Dead Zone Control Register (Default Value: 0x0000\_0000)**

| Offset:0x006C |            |             | Register Name: PDZCR67                          |
|---------------|------------|-------------|-------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                     |
| 31:16         | /          | /           | /                                               |
| 15:8          | R/W        | 0x0         | PWM67_DZ_INTV<br>PWM67 Dead Zone Interval Value |
| 7:1           | /          | /           | /                                               |

| Offset:0x006C |            |             | Register Name: PDZCR67                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                          |
| 0             | R/W        | 0x0         | PWM67_DZ_EN<br>PWM67 Dead Zone Enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 9.10.6.14 0x0080 PWM Enable Register (Default Value: 0x0000\_0000)

| Offset:0x0080 |            |             | Register Name: PER                                                                                                                                            |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31:8          | /          | /           | /                                                                                                                                                             |
| 7             | R/W        | 0x0         | PWM7_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel7 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 6             | R/W        | 0x0         | PWM6_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel6 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 5             | R/W        | 0x0         | PWM5_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel5 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 4             | R/W        | 0x0         | PWM4_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel4 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 3             | R/W        | 0x0         | PWM3_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel3 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |

| Offset:0x0080 |            |             | Register Name: PER                                                                                                                                            |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 2             | R/W        | 0x0         | PWM2_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel2 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 1             | R/W        | 0x0         | PWM1_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel1 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |
| 0             | R/W        | 0x0         | PWM0_EN<br>When PWM is enabled, the 16-bit up-counter starts working and PWM channel0 is permitted to output PWM waveform.<br>0: PWM disable<br>1: PWM enable |

#### 9.10.6.15 0x0090 PWM Group0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: PGRO                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:18          | /          | /           | /                                                                                                          |
| 17             | R/WAC      | 0x0         | PWMG0_START<br>The PWM channels selected in <b>PWMG0_CS</b> start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG0_EN<br>PWM Group0 Enable.                                                                             |
| 15:0           | R/W        | 0x0         | PWMG0_CS<br>If bit[i] is set, the PWM i is selected as one channel of PWM Group0.                          |

#### 9.10.6.16 0x0094 PWM Group1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: PGR1 |
|----------------|------------|-------------|---------------------|
| Bit            | Read/Write | Default/Hex | Description         |
| 31:18          | /          | /           | /                   |

| Offset: 0x0094 |            |             | Register Name: PGR1                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 17             | R/WAC      | 0x0         | PWMG1_START<br>The PWM channels selected in <b>PWMG1_CS</b> start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG1_EN<br>PWM Group1 Enable.                                                                             |
| 15:0           | R/W        | 0x0         | PWMG1_CS<br>If bit[i] is set, the PWM i is selected as one channel of PWM Group1.                          |

#### 9.10.6.17 0x0098 PWM Group2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: PGR2                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:18          | /          | /           | /                                                                                                          |
| 17             | R/WAC      | 0x0         | PWMG2_START<br>The PWM channels selected in <b>PWMG2_CS</b> start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG2_EN<br>PWM Group2 Enable.                                                                             |
| 15:0           | R/W        | 0x0         | PWMG2_CS<br>If bit[i] is set, the PWM i is selected as one channel of PWM Group2.                          |

#### 9.10.6.18 0x009C PWM Group3 Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: PGR3                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:18          | /          | /           | /                                                                                                          |
| 17             | R/WAC      | 0x0         | PWMG3_START<br>The PWM channels selected in <b>PWMG3_CS</b> start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG3_EN<br>PWM Group3 Enable.                                                                             |
| 15:0           | R/W        | 0x0         | PWMG3_CS<br>If bit[i] is set, the PWM i is selected as one channel of PWM Group3.                          |

**9.10.6.19 0x00C0 Capture Enable Register (Default Value: 0x0000\_0000)**

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                                                                                                      |
| 7              | R/W        | 0x0         | CAP7_EN<br>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel7 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 6              | R/W        | 0x0         | CAP6_EN<br>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel6 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 5              | R/W        | 0x0         | CAP5_EN<br>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel5 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 4              | R/W        | 0x0         | CAP4_EN<br>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel4 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 3              | R/W        | 0x0         | CAP3_EN<br>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel3 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
| 2              | R/W        | 0x0         | <p>CAP2_EN</p> <p>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel2 is permitted to capture external falling edge or rising edge.</p> <p>0: Capture disable<br/>1: Capture enable</p> |
| 1              | R/W        | 0x0         | <p>CAP1_EN</p> <p>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel1 is permitted to capture external falling edge or rising edge.</p> <p>0: Capture disable<br/>1: Capture enable</p> |
| 0              | R/W        | 0x0         | <p>CAP0_EN</p> <p>When enabling the capture function, the 16-bit up-counter starts working, and the capture channel is permitted to capture external falling edge or rising edge.</p> <p>0: Capture disable<br/>1: Capture enable</p>  |

#### 9.10.6.20 0x0100 + N\*0x20 PWM Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0100+0x0+N*0x20 (N=0~7) |            |             | Register Name: PCR                                                                                                                        |
|-----------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                               |
| 31:16                             | R/W        | 0x0         | <p>PWM_PUL_NUM</p> <p>In pulse mode, the PWM outputs pulse for PWM_CYCLE_NUM+1 times and then stops.</p>                                  |
| 15:12                             | /          | /           | /                                                                                                                                         |
| 11                                | R          | 0x0         | <p>PWM_PERIOD_RDY</p> <p>PWM Period Register Ready</p> <p>0: PWM period register is ready to write<br/>1: PWM period register is busy</p> |

| Offset:0x0100+0x0+N*0x20 (N=0~7) |            |             | Register Name: PCR                                                                                                                                                                                                                                                                           |
|----------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                  |
| 10                               | R/WAC      | 0x0         | <p>PWM_PUL_START<br/>PWM Pulse Output Start<br/>0: No effect<br/>1: Output pulse for PWM_CYCLE_NUM+1.<br/>After finishing configuration for the output pulse, set this bit once , then PWM would output waveform. After the waveform is finished, the bit will be cleared automatically.</p> |
| 9                                | R/W        | 0x0         | <p>PWM_MODE<br/>PWM Output Mode Select<br/>0: Cycle mode<br/>1: Pulse mode</p>                                                                                                                                                                                                               |
| 8                                | R/W        | 0x0         | <p>PWM_ACT_STA<br/>PWM Active State<br/>0: Low Level<br/>1: High Level</p>                                                                                                                                                                                                                   |
| 7:0                              | R/W        | 0x0         | <p>PWM_PRESCAL_K<br/>PWM pre-scale K, actual pre-scale is (K+1).<br/>K = 0, actual pre-scale: 1<br/>K = 1, actual pre-scale: 2<br/>K = 2, actual pre-scale: 3<br/>K = 3, actual pre-scale: 4<br/>...<br/>K = 255, actual pre-scale: 256</p>                                                  |

#### 9.10.6.21 0x0104 + N\*0x20 PWM Period Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x04+N*0x20 (N=0~7) |            |             | Register Name: PPR                                                                                                                                                                                                                   |
|-----------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                                                                                          |
| 31:16                             | R/W        | 0x0         | <p>PWM_ENTIRE_CYCLE<br/>Number of the entire cycles in the PWM clock.<br/>0: 1 cycle<br/>1: 2 cycles<br/>...<br/>N: N+1 cycles<br/>If the register needs to be modified dynamically, the PCLK should be faster than the PWM CLK.</p> |

| Offset:0x0100+0x04+N*0x20 (N=0~7) |            |             | Register Name: PPR                                                                                                           |
|-----------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                  |
| 15:0                              | R/W        | 0x0         | <p>PWM_ACT_CYCLE<br/>Number of the active cycles in the PWM clock.<br/>0: 0 cycle<br/>1: 1 cycle<br/>...<br/>N: N cycles</p> |

#### 9.10.6.22 0x0108 + N\*0x20 PWM Counter Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x08+N*0x20 (N=0~7) |            |             | Register Name: PCNTR                                                                                                                          |
|-----------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                   |
| 31:16                             | R/W        | 0x0         | <p>PWM_COUNTER_START<br/>PWM counter value is set for phase control.</p>                                                                      |
| 15:0                              | R          | 0x0         | <p>PWM_COUNTER_STATUS<br/>On PWM output or capture input, reading this register could get the current value of the PWM 16-bit up-counter.</p> |

#### 9.10.6.23 0x010C + N\*0x20 PWM Pulse Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0100+0x0C+N*0x20 (N=0~7) |            |             | Register Name: PPCNTR                                                                                                        |
|------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit                                | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:16                              | /          | /           | /                                                                                                                            |
| 15:0                               | R          | 0x0         | <p>PWM_PUL_COUNTER_STATUS<br/>On PWM output, reading this register could get the current value of the PWM pulse counter.</p> |

#### 9.10.6.24 0x0110 + N\*0x20 PWM Capture Control Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x10+N*0x20 (N=0~7) |            |             | Register Name: CCR |
|-----------------------------------|------------|-------------|--------------------|
| Bit                               | Read/Write | Default/Hex | Description        |
| 31:5                              | /          | /           | /                  |

| Offset:0x0100+0x10+N*0x20 (N=0~7) |            |             | Register Name: CCR                                                                                                                                                                             |
|-----------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 4                                 | R/W1C      | 0x0         | CRLF<br>When the capture channel captures a rising edge, the current value of the 16-bit up-counter is latched to CRLR, and then this bit is set 1 by hardware.<br>Write 1 to clear this bit.  |
| 3                                 | R/W1C      | 0x0         | CFLF<br>When the capture channel captures a falling edge, the current value of the 16-bit up-counter is latched to CFLR, and then this bit is set 1 by hardware.<br>Write 1 to clear this bit. |
| 2                                 | R/W        | 0x0         | CRTE<br>Rising edge capture trigger enable                                                                                                                                                     |
| 1                                 | R/W        | 0x0         | CFTE<br>Falling edge capture trigger enable                                                                                                                                                    |
| 0                                 | R/W        | 0x0         | CAPINV<br>Inverse the signal input from capture channel before 16-bit counter of capture channel.<br>0: not inverse<br>1: inverse                                                              |

#### 9.10.6.25 0x0114 + N\*0x20 PWM Capture Rise Lock Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x14+N*0x20 (N=0~7) |            |             | Register Name: CRLR                                                                                                             |
|-----------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                     |
| 31:16                             | /          | /           | /                                                                                                                               |
| 15:0                              | R          | 0x0         | CRLR<br>When the capture channel captures a rising edge, the current value of the 16-bit up-counter is latched to the register. |

#### 9.10.6.26 0x0118 + N\*0x20 PWM Capture Fall Lock Register (Default Value: 0x0000\_0000)

| Offset:0x0100+0x18+N*0x20 (N=0~7) |            |             | Register Name: CFLR |
|-----------------------------------|------------|-------------|---------------------|
| Bit                               | Read/Write | Default/Hex | Description         |
| 31:16                             | /          | /           | /                   |

| Offset:0x0100+0x18+N*0x20 (N=0~7) |            |             | Register Name: CFLR                                                                                                              |
|-----------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit                               | Read/Write | Default/Hex | Description                                                                                                                      |
| 15:0                              | R          | 0x0         | CFLR<br>When the capture channel captures a falling edge, the current value of the 16-bit up-counter is latched to the register. |

## 9.11 LEDC

### 9.11.1 Overview

The LEDC is used to control the external LED lamp.

The LEDC has the following features:

- Configurable LED output high-/low-level width
- Configurable LED reset time
- LEDC data supports DMA configuration mode and CPU configuration mode
- Maximum 1024 LEDs serial connect
- LED data transfer rate up to 800 kbit/s
- Configurable RGB display mode
- The default level of non-data output is configurable

### 9.11.2 Block Diagram

The following figure shows a block diagram of the LEDC.

Figure 9-93 LEDC Block Diagram



LEDC contains the following sub-blocks:

Table 9-32 LEDC Sub-blocks

| Sub-block  | Description                                         |
|------------|-----------------------------------------------------|
| config     | register configuration                              |
| control    | LEDC timing control and status control              |
| FIFO       | 24-bit width x 32 depth                             |
| Data_trans | Convert input data to the 0 and 1 characters of LED |

### 9.11.3 Functional Description

#### 9.11.3.1 External Signals

The following table describes the external signals of the LEDC.

Table 9-33 LEDC External Signals

| Signal  | Description                           | Type |
|---------|---------------------------------------|------|
| LEDC-DO | Intelligent Control LED Signal Output | O    |

#### 9.11.3.2 Clock Sources

The following table describes the clock sources of the LEDC.

Table 9-34 LEDC Clock Sources

| Clock Sources | Description                                    |
|---------------|------------------------------------------------|
| HOSC          | 24 MHz                                         |
| PLL_PERI(1X)  | Peripheral Clock. The default value is 600 MHz |

#### 9.11.3.3 LEDC Timing

Figure 9-94 LEDC Package Output Timing Diagram



**Figure 9-95 LEDC 1-frame Output Timing Diagram**

#### 9.11.3.4 LEDC Input Data Structure

The RGB mode of LEDC data is configurable. By default, the data is sent in GRB order, and the higher bit is transmitted first.

**Figure 9-96 LEDC Input Data Structure**

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| G7 | G6 | G5 | G4 | G3 | G2 | G1 | G0 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

#### 9.11.3.5 LEDC Typical Circuit

**Figure 9-97 LEDC Typical Circuit**

C1 is the bypass capacitor of LED light, and its value is usually 100 nF.

### 9.11.3.6 LEDC Data Input Code

Figure 9-98 LEDC Data Input Code



### 9.11.3.7 LEDC Data Transfer Time

The time parameter of the typical LED specification shows as follows.

|              |                            |                  |
|--------------|----------------------------|------------------|
| <b>T0H</b>   | 0 code, high-level time    | 220 ns to 380 ns |
| <b>T0L</b>   | 0 code, low-level time     | 580 ns to 1.6 us |
| <b>T1H</b>   | 1 code, high-level time    | 580 ns to 1.6 us |
| <b>T1L</b>   | 1 code, low-level time     | 220 ns to 420 ns |
| <b>RESET</b> | Frame unit, low-level time | > 280 us         |

### 9.11.3.8 LEDC Data Transfer Mode

Figure 9-99 LEDC Data Transfer Mode



### 9.11.3.9 LEDC Parameter

1. PAD rate > 800 kbit/s
2. LED number supported:

$T_0\text{-code}$ : 800 ns to 1980 ns,  $T_1\text{-code}$ : 800 ns to 2020 ns

When the LED refresh rate is 30 frame/s, LED number supported is  $(1 \text{ s}/30\text{-}280 \text{ us})/((800 \text{ ns to } 2020 \text{ ns})^{\star}24)$   
=1024 ↓to 681.

When the LED refresh rate is 60 frame/s, LED number supported is  $(1 \text{ s}/60\text{-}280 \text{ us})/((800 \text{ ns to } 2020 \text{ ns})^{\star}24)$   
=853 ↓to 338.

#### 9.11.3.10 LEDC Data Transfer

The LEDC supports DMA data transfer mode or CPU data transfer mode. The DMA data transfer mode is set by LEDC\_DMA\_EN

##### Data transfer in DMA mode

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, the LEDC sends DMA\_REQ to require DMA to transfer data from DRAM to LEDC. The maximum data transfer size in DMA mode is 16 words. (The internal FIFO level is 32.)

##### Data transfer in CPU mode

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, the LEDC sends LEDC\_CPUREQ\_INT to require CPU to transfer data to LEDC. The transfer data size in CPU mode is controlled by software. The internal FIFO destination address is 0x06700014. The data width is 32-bit. (The lower 24-bit is valid.)

#### 9.11.3.11 LEDC Interrupt

| Module Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO_OVERFLOW_INT | FIFO overflow interrupt.<br>The data written by external is more than the maximum storage space of LED FIFO, the LEDC will be in data loss state. At this time, software needs to deal with the abnormal situation. The processing mode is as follows.<br>The software can query LED_FIFO_DATA_REG to determine which data has been stored in the internal FIFO of LEDC. The LEDC performs soft_reset operation to refresh all data. |

| Module Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WAITDATA_TIMEOUT_INT  | <p>Wait for data timeout interrupt</p> <p>When internal FIFO of LEDC cannot get data because of some abnormal situation, the timeout interrupt is set after led_wait_data_time, now the LEDC is in WAIT_DATA state, and the LEDC outputs a level state configured by LED_POLARITY; in the course of wait_data, if the new data arrives, the LEDC will continue to send data, at this time the software needs to notice whether the waiting time of the LEDC exceeds the operation time of reset. If the waiting time of the LEDC exceeds the operation time of reset (this is equivalent to reset operation sent by LEDC), the LED may enter in refresh state, the data has not been sent.</p> |
| FIFO_CPUREQ_INT       | <p>FIFO request CPU data interrupt</p> <p>When FIFO data is less than a threshold, the interrupt will be reported to the CPU.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| LEDC_TRANS_FINISH_INT | <p>Data transfer complete interrupt</p> <p>The value indicates that the data configured as total_data_length has been transferred completely.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

LEDC interrupt usage scenario:

#### CPU mode

The software can enable GLOBAL\_INT\_EN, FIFO\_CPUREQ\_INT\_EN, WAITDATA\_TIMEOUT\_INT\_EN, FIFO\_OVERFLOW\_INT\_EN, LEDC\_TRANS\_FINISH\_INT\_EN, and cooperate with LEDC\_FIFO\_TRIG\_LEVEL to use. When FIFO\_CPUREQ\_INT is set to 1, the software can configure data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

#### DMA mode

The software can enable GLOBAL\_INT\_EN, WAITDATA\_TIMEOUT\_INT\_EN, FIFO\_OVERFLOW\_INT\_EN, LEDC\_TRANS\_FINISH\_INT\_EN, and cooperate with LEDC\_FIFO\_TRIG\_LEVEL to use. When DMA receives LEDC DMA\_REQ, DMA can transfer data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

### 9.11.4 Programming Guidelines

#### 9.11.4.1 LEDC Normal Configuration Process

**Step 1** Configure LEDC\_CLK and bus pclk.

**Step 2** Configure the written LEDC data.

- Step 3** Configure [LED\\_T01\\_TIMING\\_CTRL\\_REG](#), [LEDC\\_DATA\\_FINISH\\_CNT\\_REG](#),  
[LED\\_RESET\\_TIMING\\_CTRL\\_REG](#), [LEDC\\_WAIT\\_TIME0\\_CTRL\\_REG](#), [LEDC\\_DMA\\_CTRL\\_REG](#),  
[LEDC\\_INTERRUPT\\_CTRL\\_REG](#). Configure 0-code, 1-code, reset time, LEDC waiting time, and the number of external connected LEDC and the threshold of DMA transfer data.
- Step 4** Configure [LEDC\\_CTRL\\_REG](#) to enable LEDC\_EN, the LEDC will start to output data.
- Step 5** When the LEDC interrupt is pulled up, it indicates the configured data has transferred complete, at this time LED\_EN will be set to 0, and the read/write point of LEDC FIFO is cleared to 0.
- Step 6** Repeat step1, 2, 3, 4 to re-execute a new round of configuration, enable LEDC\_EN, the LEDC will start new data transfer.

**Figure 9-100 LEDC Normal Configuration Process**



### 9.11.4.2 LEDC Abnormal Scene Processing Flow

#### WAITDATA\_TIMEOUT Abnormal Status

- Step 1** When WAITDATA\_TIMEOUT\_INT appears, it indicates the internal FIFO data request of LEDC cannot obtain a response, at this time if the default output level is low, then the external LED may think there was a reset operation and cause LED data to be flushed incorrectly.
- Step 2** The LEDC needs to be performed soft\_reset operation (LEDC\_SOFT\_RESET=1); after soft\_reset, the LEDC\_EN will be pulled-down automatically, all internal status register and control state machine will return to the idle state, the LEDC FIFO read & write point is cleared to 0, the LEDC interrupt is cleared.
- Step 3** Setting reset\_led\_en to 1 indicates LEDC can actively send a reset operation to ensure the external LED lamp in the right state.
- Step 4** The software reads the status of reset\_led\_en, when the status value is 1, it indicates LEDC does not perform the transmission of LED reset operation; when the status value is 0, the LEDC completes the transmission of LED reset operation.
- Step 5** When LEDC reset operation finishes, the LEDC data and register configuration need to be re-operated to start re-transmission data operation.

Figure 9-101 LEDC Timeout Abnormal Processing Flow



#### FIFO Overflow Abnormal Status

**Step 1** When FIFO\_OVERFLOW\_INT appears, it indicates the data configured by software exceeds the LEDC FIFO space, at this time the redundant data will be lost.

**Step 2** The software needs to read data in **LEDC\_FIFO\_DATA\_X** to confirm the lost data.

**Step 3** The software re-configures the lost data to the LEDC.

**Step 4** If the software uses the soft\_reset operation, the operation is the same with the timeout abnormal processing flow.

**Figure 9-102 FIFO Overflow Abnormal Processing Flow**



### 9.11.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| LEDC        | 0x02008000   |

| Register Name             | Offset        | Description                          |
|---------------------------|---------------|--------------------------------------|
| LEDC_CTRL_REG             | 0x0000        | LEDC Control Register                |
| LED_T01_TIMING_CTRL_REG   | 0x0004        | LEDC T0 & T1 Timing Control Register |
| LEDC_DATA_FINISH_CNT_REG  | 0x0008        | LEDC Data Finish Counter Register    |
| LED_RESET_TIMING_CTRL_REG | 0x000C        | LEDC Reset Timing Control Register   |
| LEDC_WAIT_TIME0_CTRL_REG  | 0x0010        | LEDC Wait Time0 Control Register     |
| LEDC_DATA_REG             | 0x0014        | LEDC Data Register                   |
| LEDC_DMA_CTRL_REG         | 0x0018        | LEDC DMA Control Register            |
| LEDC_INT_CTRL_REG         | 0x001C        | LEDC Interrupt Control Register      |
| LEDC_INT_STS_REG          | 0x0020        | LEDC Interrupt Status Register       |
| LEDC_WAIT_TIME1_CTRL_REG  | 0x0028        | LEDC Wait Time1 Control Register     |
| LEDC_FIFO_DATA_REG        | 0x0030+0x04*N | LEDC FIFO Data Register              |

### 9.11.6 Register Description

#### 9.11.6.1 0x0000 LEDC Control Register (Default Value: 0x0000\_003C)

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                          |
| 28:16          | R/W        | 0x0         | <p><b>TOTAL_DATA_LENGTH</b><br/>           Total length of transfer data (range: 0 to 8K, unit: 32-bit, only low 24-bit is valid)<br/>           The field is recommended to be set to an integer multiple of (LED_NUM+1).<br/>           If TOTAL_DATA_LENGTH is greater than (LED_NUM+1), but non-integer multiple, the last frame of data will transfer data less than (LED_NUM+1).</p> |
| 15:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                          |
| 10             | R/W        | 0x0         | <p><b>RESET_LED_EN</b><br/>           Write operation:</p>                                                                                                                                                                                                                                                                                                                                 |

| Offset: 0x0000 |                     |                  | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|----------------|---------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------|---------------------|------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit            | Read/Write          | Default/Hex      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                |                     |                  | <p>The software writes 1 to the bit, the CPU triggers LEDC to transfer a reset to LED.</p> <p><b>Only when LEDC is in IDLE status, the reset can be performed. After the reset finished, the control state machine returns to the IDLE status. To return LEDC to the IDLE status, it also needs to be used with SOFT_RESET.</b></p> <p><b>When the software sets the bit, the software can read the bit to check if the reset is complete.</b></p> <p>Read operation:</p> <p>0: LEDC completes the transmission of the LED reset operation<br/>1: LEDC does not complete the transmission of the LED reset operation</p>                                                                                                                                                                                                                                                                                                                                                                                                                          |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 9              | /                   | /                | <p>LED_RGB_MODE</p> <table> <tr><td>000</td><td>GRB (bypass)</td></tr> <tr><td>001</td><td>GBR</td></tr> <tr><td>010</td><td>RGB</td></tr> <tr><td>011</td><td>RBG</td></tr> <tr><td>100</td><td>BGR</td></tr> <tr><td>101</td><td>BRG</td></tr> </table> <p>By default, the software configures data to LEDC according to GRB (MSB) mode, the LEDC internal combines data to output to the external LED.</p> <p>Other modes configure as follows.</p> <table border="1"> <thead> <tr> <th>Software Mode</th> <th>Input Configuration</th> <th>LEDC Output Mode</th> </tr> </thead> <tbody> <tr> <td rowspan="6">GRB</td> <td>000</td> <td>GRB</td> </tr> <tr> <td>001</td> <td>GBR</td> </tr> <tr> <td>010</td> <td>RGB</td> </tr> <tr> <td>011</td> <td>RBG</td> </tr> <tr> <td>100</td> <td>BGR</td> </tr> <tr> <td>101</td> <td>BRG</td> </tr> <tr> <td rowspan="4">GBR</td> <td>000</td> <td>GBR</td> </tr> <tr> <td>001</td> <td>GRB</td> </tr> <tr> <td>010</td> <td>BGR</td> </tr> <tr> <td>011</td> <td>BRG</td> </tr> </tbody> </table> | 000 | GRB (bypass) | 001 | GBR | 010 | RGB | 011 | RBG | 100 | BGR | 101 | BRG | Software Mode | Input Configuration | LEDC Output Mode | GRB | 000 | GRB | 001 | GBR | 010 | RGB | 011 | RBG | 100 | BGR | 101 | BRG | GBR | 000 | GBR | 001 | GRB | 010 | BGR | 011 | BRG |
| 000            | GRB (bypass)        |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 001            | GBR                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 010            | RGB                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 011            | RBG                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 100            | BGR                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 101            | BRG                 |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Software Mode  | Input Configuration | LEDC Output Mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GRB            | 000                 | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 001                 | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 010                 | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 011                 | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 100                 | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 101                 | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GBR            | 000                 | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 001                 | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 010                 | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                | 011                 | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |              |     |     |     |     |     |     |     |     |     |     |               |                     |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                |     |     |  |
|----------------|------------|-------------|-----------------------------------------------------------------------------|-----|-----|--|
| Bit            | Read/Write | Default/Hex | Description                                                                 |     |     |  |
|                |            |             | RGB                                                                         | 100 | RGB |  |
|                |            |             |                                                                             | 101 | RBG |  |
|                |            |             |                                                                             | 000 | RGB |  |
|                |            |             |                                                                             | 001 | RBG |  |
|                |            |             |                                                                             | 010 | GRB |  |
|                |            |             |                                                                             | 011 | GBR |  |
|                |            |             |                                                                             | 100 | BRG |  |
|                |            |             |                                                                             | 101 | BGR |  |
| RBG            |            |             |                                                                             | 000 | RBG |  |
|                |            |             |                                                                             | 001 | RGB |  |
|                |            |             |                                                                             | 010 | BRG |  |
|                |            |             |                                                                             | 011 | BGR |  |
|                |            |             |                                                                             | 100 | GRB |  |
|                |            |             |                                                                             | 101 | GBR |  |
|                |            |             |                                                                             | 000 | BGR |  |
|                |            |             |                                                                             | 001 | BRG |  |
| BGR            |            |             |                                                                             | 010 | GBR |  |
|                |            |             |                                                                             | 011 | GRB |  |
|                |            |             |                                                                             | 100 | RBG |  |
|                |            |             |                                                                             | 101 | RGB |  |
|                |            |             |                                                                             | 000 | BRG |  |
|                |            |             |                                                                             | 001 | BGR |  |
|                |            |             |                                                                             | 010 | RBG |  |
|                |            |             |                                                                             | 011 | GRB |  |
| 5              | R/W        | 0x1         | LED_MSB_TOP<br>Adjust sequence of the combined GRB data<br>0: LSB<br>1: MSB |     |     |  |
|                |            |             | LED_MSB_G<br>MSB control for Green data<br>0: LSB                           |     |     |  |
|                |            |             |                                                                             |     |     |  |
|                |            |             |                                                                             |     |     |  |
|                |            |             |                                                                             |     |     |  |

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | 1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3              | R/W        | 0x1         | LED_MSB_R<br>MSB control for Red data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x1         | LED_MSB_B<br>MSB control for Blue data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | R/W1C      | 0x0         | LEDC_SOFT_RESET<br>LEDC soft reset<br>Write 1 to clear it automatically.<br><br>The ranges of LEDC soft reset include the following points: all internal status registers, the control state machine returns to in idle status, the LEDC FIFO read & write point is cleared to 0, the LEDC interrupt is cleared; and the affected registers are followed.<br><br>1.LEDC_CTRL_REG (LEDC_EN is cleared to 0);<br>2. PLL_T0&1_TIMING_CTRL_REG remains unchanged;<br>3. LEDC_DATA_FINISH_CNT_REG (LEDC_DATA_FINISH_CNT is cleared to 0);<br>4.LED_RESET_TIMING_CTRL_REG remains unchanged;<br>5. LEDC_WAIT_TIME_CTRL_REG remains unchanged;<br>6. LEDC_DMA_CTRL_REG remains unchanged;<br>7. LEDC_INTERRUPT_CTRL_REG remains unchanged;<br>8.LEDC_INT_STS_REG is cleared to 0;<br>9. LEDC_CLK_GATING_REG remains unchanged;<br>10.LEDC_FIFO_DATA_REG remains unchanged; |
| 0              | R/W        | 0x0         | LEDC_EN<br>LEDC Enable<br>0: Disable<br>1: Enable<br><br>That the bit is enabled indicates LEDC can be started when LEDC data finished transmission or LEDC_EN is cleared to 0 by hardware in LEDC_SOFT_RESET situation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 9.11.6.2 0x0004 LEDC T0 & T1 Timing Control Register (Default Value: 0x0286\_01D3)

| Offset: 0x0004 |            |             | Register Name: LED_T01_TIMING_CTRL_REG                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31:27          | /          | /           | /                                                                                                                                                                         |
| 26:21          | R/W        | 0x14        | T1H_TIME<br>LED T1H time<br>Unit: cycle (24 MHz), T1H_TIME = 42 ns*(N+1)<br>The default value is 882 ns, the range is 80 ns–2560 ns.<br>N: 1–3F. When is 0, T1H_TIME = 3F |
| 20:16          | R/W        | 0x6         | T1L_TIME<br>LED T1L time<br>Unit: cycle (24 MHz), T1L_TIME = 42 ns*(N+1)<br>The default value is 294 ns, the range is 80 ns–1280 ns.<br>N: 1–1F. When is 0, T1L_TIME = 1F |
| 15:11          | /          | /           | /                                                                                                                                                                         |
| 10:6           | R/W        | 0x7         | TOH_TIME<br>LED TOh time<br>Unit: cycle (24 MHz), TOH_TIME = 42 ns*(N+1)<br>The default value is 336 ns, the range is 80 ns–1280 ns.<br>N: 1–1F. When is 0, TOH_TIME = 1F |
| 5:0            | R/W        | 0x13        | TOL_TIME<br>LED TOl time<br>Unit: cycle (24 MHz), TOL_TIME = 42 ns*(N+1)<br>The default value is 840 ns, the range is 80 ns–2560 ns.<br>N: 1–3F. When is 0, TOL_TIME = 3F |

### 9.11.6.3 0x0008 LEDC Data Finish Counter Register (Default Value: 0x1D4C\_0000)

| Offset: 0x0008 |            |             | Register Name: LEDC_DATA_FINISH_CNT_REG |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:30          | /          | /           | /                                       |

| Offset: 0x0008 |            |             | Register Name: LEDC_DATA_FINISH_CNT_REG                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 29:16          | R/W        | 0x1D4C      | <p>LED_WAIT_DATA_TIME<br/>The value is the time that internal FIFO in LEDC is waiting for data. When the time is exceeded, the LEDC will send the wait_data_timeout_int interrupt. (This is an abnormal situation, software needs to reset LEDC.)<br/>The value is about 300 us by default.<br/>The adjust range is 80 ns–655 us.<br/><math>\text{led\_wait\_data\_time} = 42\text{ ns} * (\text{N} + 1)</math>.<br/>N: 1–1FFF. When the field is 0, LEDC_WAIT_DATA_TIME=1FFF</p> |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 12:0           | R          | 0x0         | <p>LED_DATA_FINISH_CNT<br/>The value is the total LED data that have been sent. (Range: 0–8k)</p>                                                                                                                                                                                                                                                                                                                                                                                 |

#### 9.11.6.4 0x000C LEDC Reset Timing Control Register (Default Value: 0x1D4C\_0000)

| Offset: 0x000C |            |             | Register Name: LED_RESET_TIMING_CTRL_REG                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:29          | /          | /           | /                                                                                                                                                                                                                             |
| 28:16          | R/W        | 0x1D4C      | <p>TR_TIME<br/>Reset time control of LED lamp<br/>Unit: cycle (24 MHz), <math>\text{tr\_time} = 42\text{ ns} * (\text{N} + 1)</math><br/>The default value is 300 us.<br/>The adjust range is 80 ns–327 us.<br/>N: 1–1FFF</p> |
| 15:10          | /          | /           | /                                                                                                                                                                                                                             |
| 9:0            | R/W        | 0x0         | <p>LED_NUM<br/>The value is the number of external LED lamp. Maximum up to 1024.<br/>The default value 0 indicates that 1 LED lamp is external connected. The range is from 0 to 1023.</p>                                    |

### 9.11.6.5 0x0010 LEDC Wait Time 0 Control Register (Default Value: 0x0000\_00FF)

| Offset: 0x0010 |            |             | Register Name: LEDC_WAIT_TIME0_CTRL_REG                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:9           | /          | /           | /                                                                                                                                                                                              |
| 8              | R/W        | 0x0         | <p>WAIT_TIM0_EN<br/>WAIT_TIME0 enable<br/>When it is 1, the controller automatically inserts waiting time between LED package data.<br/>0: Disable<br/>1: Enable</p>                           |
| 7:0            | R/W        | 0xFF        | <p>TOTAL_WAIT_TIME0<br/>Waiting time between 2 LED data. The LEDC output is low level.<br/>The adjust range is 80 ns–10 us.<br/>wait_time0=42 ns*(N+1)<br/>Unit: cycle(24 MHz)<br/>N: 1–FF</p> |

### 9.11.6.6 0x0014 LEDC Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: LEDC_DATA_REG                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:0           | W          | 0x0         | LEDC DATA<br>LED display data (the lower 24-bit is valid) |

### 9.11.6.7 0x0018 LEDC DMA Control Register (Default Value: 0x0000\_002F)

| Offset: 0x0018 |            |             | Register Name: LEDC_DMA_CTRL_REG                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:6           | /          | /           | /                                                                                                                                     |
| 5              | R/W        | 0x1         | <p>LEDC_DMA_EN<br/>LEDC DMA request enable<br/>0: Disable request of DMA transfer data<br/>1: Enable request of DMA transfer data</p> |

| Offset: 0x0018 |            |             | Register Name: LEDC_DMA_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4:0            | R/W        | 0x0F        | <p>LEDC_FIFO_TRIG_LEVEL<br/>The remaining space of internal FIFO in LEDC<br/>The internal FIFO in LEDC is 24*32.</p> <p>When the remaining space of internal FIFO in LEDC is more than or equal to LEDFIFO_TRIG_LEVEL, the DMA or the CPU request will generate. The default value is 15.</p> <p>The adjusted value is from 1 to 31. The recommended configuration is 7 or 15. When the configuration value is 0, LEDFIFO_TRIG_LEVEL=F.</p> |

#### 9.11.6.8 0x001C LEDC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: LEDC_INTERRUPT_CTRL_REG                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                             |
| 31:6           | /          | /           | /                                                                                                                                                                                                                       |
| 5              | R/W        | 0x0         | <p>GLOBAL_INT_EN<br/>Global interrupt enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                           |
| 4              | R/W        | 0x0         | <p>FIFO_OVERFLOW_INT_EN<br/>FIFO overflow interrupt enable<br/>When the data written by the software is more than the internal FIFO level of LEDC, the LEDC is in the data loss state.<br/>0: Disable<br/>1: Enable</p> |
| 3              | R/W        | 0x0         | <p>WAITDATA_TIMEOUT_INT_EN<br/>The internal FIFO in LEDC cannot get data because of some abnormal situation, after the time of led_wait_data_time, the interrupt will be enabled.<br/>0: Disable<br/>1: Enable</p>      |
| 2              | /          | /           | /                                                                                                                                                                                                                       |
| 1              | R/W        | 0x0         | <p>FIFO_CPUREQ_INT_EN<br/>FIFO request CPU data interrupt enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                       |

| Offset: 0x001C |            |             | Register Name: LEDC_INTERRUPT_CTRL_REG                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 0              | R/W        | 0x0         | <p>LED_TRANS_FINISH_INT_EN<br/>Data transmission complete interrupt enable<br/>0: Disable<br/>1: Enable</p> |

#### 9.11.6.9 0x0020 LEDC Interrupt Status Register (Default Value: 0x0002\_0000)

| Offset: 0x0020 |            |             | Register Name: LEDC_INT_STS_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 17             | R          | 0x1         | <p>FIFO_EMPTY<br/>FIFO empty status flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16             | R          | 0x0         | <p>FIFO_FULL<br/>FIFO full status flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:10          | R          | 0x0         | <p>FIFO_WLW<br/>FIFO internal valid data depth<br/>It indicates the space FIFO has been occupied.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4              | R/W1C      | 0x0         | <p>FIFO_OVERFLOW_INT<br/>FIFO overflow interrupt<br/>The data written by external is more than the maximum storage space of LED FIFO, the LEDC will be in the data loss state. At this time, the software needs to deal with the abnormal situation.<br/>The processing mode is as follows.<br/>           (1) The software can query LED_FIFO_DATA_REG to determine which data has been stored in the internal FIFO of LEDC.<br/>           (2) The LEDC performs soft_reset operation to refresh all data.<br/>0: FIFO not overflow<br/>1: FIFO overflow</p> |

| Offset: 0x0020 |            |             | Register Name: LEDC_INT_STS_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3              | R/W1C      | 0x0         | <p>WAITDATA_TIMEOUT_INT</p> <p>When internal FIFO of LEDC cannot get data because of some abnormal situation, after led_wait_data_time, the timeout interrupt is set, the LEDC is in WAIT_DATA state, the LEDC outputs a level state configured by LED_POLARITY; in the course of wait_data, if the new data arrives, the LEDC will continue to send data, at this time software needs to notice whether the waiting time of LEDC exceeds the operation time of reset. If the waiting time of LEDC exceeds the operation time of reset (this is equivalent to reset operation sent by LEDC), the LED may enter in refresh state, the data has not been sent.</p> <p>0: LEDC not timeout<br/>1: LEDC timeout</p> |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1              | R/W1C      | 0x0         | <p>FIFO_CPUREQ_INT</p> <p>FIFO request CPU data interrupt</p> <p>When FIFO data is less than the threshold, the interrupt will be reported to the CPU.</p> <p>0: FIFO does not request that CPU transfers data<br/>1: FIFO requests that CPU transfers data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | R/W1C      | 0x0         | <p>LED_TRANS_FINISH_INT</p> <p>Data transfer complete interrupt</p> <p>The value indicates that the data configured as total_data_length is transferred completely.</p> <p>0: Data is not transferred completely<br/>1: Data is transferred completely</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 9.11.6.10 0x0028 LEDC Wait Time 1 Control Register (Default Value: 0x01FF\_FFFF)

| Offset: 0x0028 |            |             | Register Name: LEDC_WAIT_TIME1_CTRL_REG                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31             | R/W        | 0x0         | <p>WAIT_TIM1_EN</p> <p>0: Disable<br/>1: Enable</p> <p>WAIT_TIME1 enable</p> <p>When the bit is 1, the controller automatically inserts the waiting time between the LED frame data.</p> |

| Offset: 0x0028 |            |             | Register Name: LEDC_WAIT_TIME1_CTRL_REG                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                        |
| 30:0           | R/W        | 0x01FFFFFF  | TOTAL_WAIT_TIME1<br>Waiting time between 2 frame data.<br>The LEDC output is low level.<br>The adjust range is 80 ns– 85 s. wait_time1=42 ns*(N+1)<br>Unit: cycle (24 MHz)<br>N: 0x80–0x7FFFFFFF<br>If the value is 0, TOTAL_WAIT_TIME1=0x7FFFFFFF |

#### 9.11.6.11 0x0030+N\*0x04 LEDC FIFO Data Register X (Default Value: 0x0000\_0000)

| Offset: 0x0030+N*0x04 (N=0–31) |            |             | Register Name: LEDC_FIFO_DATA_X                                              |
|--------------------------------|------------|-------------|------------------------------------------------------------------------------|
| Bit                            | Read/Write | Default/Hex | Description                                                                  |
| 31:0                           | R          | 0x0         | LEDC_FIFO_DATA_X<br>Internal FIFO data of LEDC<br>The lower 24-bit is valid. |

## 9.12 EMAC

### 9.12.1 Overview

The Ethernet Medium Access Controller (EMAC) enables a host to transmit and receive data over Ethernet in compliance with the IEEE 802.3-2002 standard. It supports 10/100/1000 Mbit/s external PHY with RMII/RGMII interface in full-duplex and half-duplex modes. The internal DMA is designed for packet-oriented data transfers based on a linked list of descriptors.

The EMAC has the following features:

- One 10/100/1000 Mbit/s Ethernet port with reduced gigabit media independent interface (RGMII) and reduced media independent interface (RMII) interfaces, for connecting the external EPHY
- Compliant with IEEE 802.3-2002 standard
- Provides the management data input/output (MDIO) interface for PHY device configuration and management with configurable clock frequencies
- Supports both full-duplex and half-duplex operations
- Programmable frame length to support Standard or Jumbo Ethernet frames with sizes up to 16 KB
- Supports a variety of flexible address filtering modes
- Separate 32-bit status returned for transmission and reception packets
- Optimization for packet-oriented DMA transfers with frame delimiters
  - Supports linked-list descriptor list structure
    - Descriptor architecture, allowing large blocks of data transfer with minimum CPU intervention; each descriptor can transfer up to 4 KB of data
    - Comprehensive status reporting for normal operation and transfers with errors
- 4 KB TXFIFO for transmission packets and 16 KB RXFIFO for reception packets
- Programmable interrupt options for different operational conditions

### 9.12.2 Block Diagram

The following figure shows the block diagram of EMAC.

Figure 9-103 EMAC Block Diagram



### 9.12.3 Functional Description

#### 9.12.3.1 External Signals

The following table describes the pin mapping of EMAC.

Table 9-35 EMAC Pin Mapping

| Pin Name                 | RGMII | RMII   |
|--------------------------|-------|--------|
| RGMII-RXD3               | RXD3  | /      |
| RGMII-RXD2               | RXD2  | /      |
| RGMII-RXD1/RMII-RXD1     | RXD1  | RXD1   |
| RGMII-RXD0/RMII-RXD0     | RXD0  | RXD0   |
| RGMII-RXCK               | RXCK  | /      |
| RGMII-RXCTRL/RMII-CRS-DV | RXCTL | CRS-DV |
| RGMII-TXD3               | TXD3  | /      |
| RGMII-TXD2               | TXD2  | /      |
| RGMII-TXD1/RMII-TXD1     | TXD1  | TXD1   |
| RGMII-TXD0/RMII-TXD0     | TXD0  | TXD0   |
| RGMII-TXCK/RMII-TXCK     | TXCK  | TXCK   |
| RGMII-TXCTRL/RMII-TXEN   | TXCTL | TXEN   |
| RGMII-CLKIN/RMII-RXER    | CLKIN | RXER   |
| MDC                      | MDC   | MDC    |
| MDIO                     | MDIO  | MDIO   |

| Pin Name | RGMII    | RMII     |
|----------|----------|----------|
| EPHY-25M | EPHY-25M | EPHY-25M |

The following table describes the pin list of RGMII.

Table 9-36 EMAC RGMII Pin List

| Pin Name       | Description                           | Type |
|----------------|---------------------------------------|------|
| RGMII-TXD[3:0] | EMAC RGMII transmit data              | O    |
| RGMII-TXCTRL   | EMAC RGMII transmit control           | O    |
| RGMII-TXCK     | EMAC RGMII transmit clock             | O    |
| RGMII-RXD[3:0] | EMAC RGMII receive data               | I    |
| RGMII-RXCTRL   | EMAC RGMII receive control            | I    |
| RGMII-RXCK     | EMAC RGMII receive clock              | I    |
| RGMII-CKIN     | EMAC RGMII 125M reference clock input | I    |
| MDC            | EMAC management data clock            | O    |
| MDIO           | EMAC management data input output     | I/O  |
| EPHY-25M       | 25 MHz output for EMAC PHY            | O    |

The following table describes the pin list of RMII.

Table 9-37 EMAC RMII Pin List

| Pin Name      | Description                       | Type |
|---------------|-----------------------------------|------|
| RMII-TXD[1:0] | EMAC RMII transmit data           | O    |
| RMII-TXEN     | EMAC RMII transmit enable         | O    |
| RMII-TXCK     | EMAC RMII transmit clock          | I    |
| RMII-RXD[1:0] | EMAC RMII receive data            | I    |
| RMII-CRS-DV   | EMAC RMII receive data valid      | I    |
| RMII-RXER     | EMAC RMII receive error           | I    |
| MDC           | EMAC management data clock        | O    |
| MDIO          | EMAC management data input output | I/O  |
| EPHY-25M      | 25 MHz output for EMAC PHY        | O    |

### 9.12.3.2 Clock Characteristics

The following table describes the clock of EMAC.

**Table 9-38 EMAC Clock Characteristics**

| Clock Name             | Description                                                                        | Type |
|------------------------|------------------------------------------------------------------------------------|------|
| RGMII0-TXCK/RMII0-TXCK | In RGMII mode, output 2.5 MHz/25 MHz/125 MHz.<br>In RMII mode, input 5 MHz/50 MHz. | O/I  |
| RGMII0-RXCK            | In RGMII mode, input 2.5 MHz/25 MHz/125 MHz.<br>In RMII mode, no input.            | I    |
| RGMII0-CLKIN           | In RGMII mode, input 125M Reference Clock.<br>In RMII mode, no clock.              | I    |

### 9.12.3.3 Typical Application

**Figure 9-104 EMAC Typical Application**



### 9.12.3.4 EMAC RX/TX Descriptor

The internal DMA of EMAC transfers data between host memory and internal RX/TX FIFO by a linked list of descriptors. Each descriptor consists of four words and contains some necessary information to transfer TX and RX frames. The following figure shows the descriptor list structure. The address of each descriptor must be 32-bit aligned.

Figure 9-105 EMAC RX/TX Descriptor List



### 9.12.3.5 TX Descriptor

#### 1st Word of TX Descriptor

| Bits  | Description                                                                                                                                                                                             |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | TX_DESC_CTL<br>When set, the current descriptor can be used by DMA. This bit is cleared by DMA when the whole frame is transmitted or all data in the buffer of the current descriptor are transmitted. |
| 30:17 | Reserved                                                                                                                                                                                                |
| 16    | TX_HEADER_ERR<br>When set, the checksum of the header for the transmitted frame is wrong.                                                                                                               |
| 15    | Reserved                                                                                                                                                                                                |
| 14    | TX_LENGTH_ERR<br>When set, the length of the transmitted frame is wrong.                                                                                                                                |
| 13    | Reserved                                                                                                                                                                                                |
| 12    | TX_PAYLOAD_ERR<br>When set, the checksum of the payload for the transmitted frame is wrong.                                                                                                             |
| 11    | Reserved                                                                                                                                                                                                |
| 10    | TX_CRS_ERR<br>When set, the carrier is lost during transmission.                                                                                                                                        |
| 9     | TX_COL_ERR_0<br>When set, the frame is aborted because of a collision after the contention period.                                                                                                      |
| 8     | TX_COL_ERR_1<br>When set, the frame is aborted because of too many collisions.                                                                                                                          |
| 7     | Reserved                                                                                                                                                                                                |

| Bits | Description                                                                                |
|------|--------------------------------------------------------------------------------------------|
| 6:3  | TX_COL_CNT<br>The number of collisions before transmission.                                |
| 2    | TX_DEFER_ERR<br>When set, the frame is aborted because of too much deferral.               |
| 1    | TX_UNDERFLOW_ERR<br>When set, the frame is aborted because of the TX FIFO underflow error. |
| 0    | TX_DEFER<br>When set in Half-Duplex mode, the EMAC defers the frame transmission.          |

### 2nd Word of TX Descriptor

| Bits  | Description                                                                                                                   |
|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 31    | TX_INT_CTL<br>When it is set and the current frame has been transmitted, the TX_INT in Interrupt Status Register will be set. |
| 30    | LAST_DESC<br>When it is set, the current descriptor is the last one of the current frame.                                     |
| 29    | FIR_DESC<br>When it is set, the current descriptor is the first one of the current frame.                                     |
| 28:27 | CHECKSUM_CTL<br>These bits control to insert checksum in the transmit frame.                                                  |
| 26    | CRC_CTL<br>When it is set, the CRC field is not transmitted.                                                                  |
| 25:11 | Reserved                                                                                                                      |
| 10:0  | BUF_SIZE<br>The size of the buffer specified by the current descriptor.                                                       |

### 3rd Word of TX Descriptor

| Bits | Description                                                                |
|------|----------------------------------------------------------------------------|
| 31:0 | BUF_ADDR<br>The address of the buffer specified by the current descriptor. |

**4th Word of TX Descriptor**

| Bits | Description                                                                             |
|------|-----------------------------------------------------------------------------------------|
| 31:0 | <b>NEXT_DESC_ADDR</b><br>The address of the next descriptor. It must be 32-bit aligned. |

**9.12.3.6 RX Descriptor****1st Word of RX Descriptor**

| Bits  | Description                                                                                                                                                                                                                                                              |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | <b>RX_DESC_CTL</b><br>When it is set, the current descriptor can be used by DMA. This bit is cleared by DMA when the complete frame is received or the buffer of the current descriptor is full.                                                                         |
| 30    | <b>RX_DAF_FAIL</b><br>When it is set, the current frame does not pass the DA filter.                                                                                                                                                                                     |
| 29:16 | <b>RX_FRM_LEN</b><br>When LAST_DESC is not set and no error bit is set, this field is the length of received data for the current frame.<br>When LAST_DESC is set, RX_OVERFLOW_ERR and RX_NO_ENOUGH_BUF_ERR are not set, this field is the length of the received frame. |
| 15    | Reserved                                                                                                                                                                                                                                                                 |
| 14    | <b>RX_NO_ENOUGH_BUF_ERR</b><br>When it is set, the current frame is clipped because of no enough buffer.                                                                                                                                                                 |
| 13    | <b>RX_SAF_FAIL</b><br>When it is set, the current frame does not pass the SA filter.                                                                                                                                                                                     |
| 12    | Reserved                                                                                                                                                                                                                                                                 |
| 11    | <b>RX_OVERFLOW_ERR</b><br>When it is set, a buffer overflow error occurred and the current frame is wrong.                                                                                                                                                               |
| 10    | Reserved                                                                                                                                                                                                                                                                 |
| 9     | <b>FIR_DESC</b><br>When it is set, the current descriptor is the first descriptor of the current frame.                                                                                                                                                                  |
| 8     | <b>LAST_DESC</b><br>When it is set, the current descriptor is the last descriptor of the current frame.                                                                                                                                                                  |
| 7     | <b>RX_HEADER_ERR</b><br>When it is set, the checksum of the frame header is wrong.                                                                                                                                                                                       |

| Bits | Description                                                                                              |
|------|----------------------------------------------------------------------------------------------------------|
| 6    | RX_COL_ERR<br>When it is set, there is a late collision during the reception in half-duplex mode.        |
| 5    | Reserved                                                                                                 |
| 4    | RX_LENGTH_ERR<br>When it is set, the length of the current frame is wrong.                               |
| 3    | RX_PHY_ERR<br>When it is set, the receive error signal from PHY is asserted during the reception.        |
| 2    | Reserved                                                                                                 |
| 1    | RX_CRC_ERR<br>When it is set, the CRC field of the received frame is wrong.                              |
| 0    | RX_PAYLOAD_ERR<br>When it is set, the checksum or length of the payload for the received frame is wrong. |

#### 2nd Word of RX Descriptor

| Bits  | Description                                                                             |
|-------|-----------------------------------------------------------------------------------------|
| 31    | RX_INT_CTL<br>When it is set and a frame has been received, the RX_INT will not be set. |
| 30:11 | Reserved                                                                                |
| 10:0  | BUF_SIZE<br>The size of the buffer is specified by the current descriptor.              |

#### 3rd Word of RX Descriptor

| Bits | Description                                                                |
|------|----------------------------------------------------------------------------|
| 31:0 | BUF_ADDR<br>The address of the buffer specified by the current descriptor. |

#### 4th Word of RX Descriptor

| Bits | Description                                                                              |
|------|------------------------------------------------------------------------------------------|
| 31:0 | NEXT_DESC_ADDR<br>The address of the next descriptor. This field must be 32-bit aligned. |

## 9.12.4 Programming Guidelines

### 9.12.4.1 EMAC System Configuration

Perform the following steps:

- Step 1** Write 0 to **EMAC\_BGR\_REG**[bit16] to assert the module reset.
- Step 2** Write 1 to **EMAC\_BGR\_REG**[bit16] to deassert the module reset.
- Step 3** Write 1 to **EMAC\_BGR\_REG**[bit0] to enable the bus clock of the module.
- Step 4** Configure the pin interfaces of EMAC by setting GPIO module.
- Step 5** Configure **EMAC\_EPHY\_CLK\_REG0** to set the transmission clock source of RGMII/RMII.

For RGMII RXCLK/CLK125M:

In RGMII mode, in addition to the configuration of the transmission clock source, it is generally necessary to adjust the timing by configuring the transmission clock delay, reception clock delay, transmission clock reverse, reception clock reverse.

- Write 0 to the bit[13] and write 1 to the bit[2] to select the RGMII interface.
- If selecting RXCLK as the clock source of RGMII, write 2 to the bit[1:0]; if selecting CLK125M as the clock source of RGMII, write 1 to the bit[1:0].
- Write 0 to the bit[3], write 0 to the bit[4], write 31 to the bit[9:5], and write 7 to the bit[12:10] to transmit the reception sequence adjustment.

For RMII TXCLK:

- Write 1 to the bit[13] and write 0 to the bit[2] to select the RMII interface.
- Write 0 to the bit[0] to select TXCLK as the clock source of RMII.

The configuration value of **EMAC\_EPHY\_CLK\_REG0** can refer to the following table.

Table 9-39 EMAC\_EPHY\_CLK\_REG0 Configuration Value

| EMAC_EPHY_CLK_REG0 | PHY_SEL | RMII_EN | ETXDC      | ERXDC    | ERXIE | ETXIE | RMII/RGMII | ETCS     |
|--------------------|---------|---------|------------|----------|-------|-------|------------|----------|
|                    | Bit15   | Bit13   | Bit[12:10] | Bit[9:5] | Bit4  | Bit3  | Bit2       | Bit[1:0] |
| RGMII              | 0       | 0       | 7          | 31       | 0     | 0     | 1          | 1/2      |
| RMII               | 0       | 1       | 0          | 0        | 0     | 0     | 0          | 0        |

### 9.12.4.2 EMAC Initialization

- Step 1** Write 1 to **EMAC\_BASIC\_CTL1**[bit0] to perform the software reset.

- Step 2** Write 1 to EMAC\_BASIC\_CTL1[bit1] to set the DMA priority of TX/RX.
- Step 3** Configure EMAC\_TX\_CTL1 and EMAC\_RX\_CTL1 to set the configuration of DMA TX and DMA RX.
- Step 4** Configure EMAC\_INT\_EN to set the corresponding interrupts and shield the needless interrupts.
- Step 5** Configure EMAC\_TX\_DMA\_LIST and EMAC\_RX\_DMA\_LIST to set the first address of the TX descriptor and the RX descriptor, respectively.
- Step 6** Configure EMAC\_TX\_CTL0 and EMAC\_RX\_CTL0 to set the TX and RX parameters. Configure EMAC\_BASIC\_CTL0 to set the speed, duplex mode, loopback configuration. (If enabled the auto-negotiation, the configuration is performed as a result of the negotiation)
- Step 7** Configure EMAC\_RX\_FRM\_FLT to set the RX frame filter.
- Step 8** Configure EMAC\_TX\_FLOW\_CTL and EMAC\_RX\_CTL0 to set the control mechanism of TX and RX.
- Step 9** Clear all interrupt flags.
- Step 10** Write 1 to EMAC\_TX\_CTL0[bit31] and write 1 to EMAC\_RX\_CTL0[bit31] to enable the TX and RX functions.

### 9.12.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| EMAC        | 0x04500000   |

| Register Name         | Offset | Description                                    |
|-----------------------|--------|------------------------------------------------|
| EMAC_BASIC_CTL0       | 0x0000 | EMAC Basic Control Register0                   |
| EMAC_BASIC_CTL1       | 0x0004 | EMAC Basic Control Register1                   |
| EMAC_INT_STA          | 0x0008 | EMAC Interrupt Status Register                 |
| EMAC_INT_EN           | 0x000C | EMAC Interrupt Enable Register                 |
| EMAC_TX_CTL0          | 0x0010 | EMAC Transmit Control Register0                |
| EMAC_TX_CTL1          | 0x0014 | EMAC Transmit Control Register1                |
| EMAC_TX_FLOW_CTL      | 0x001C | EMAC Transmit Flow Control Register            |
| EMAC_TX_DMA_DESC_LIST | 0x0020 | EMAC Transmit Descriptor List Address Register |
| EMAC_RX_CTL0          | 0x0024 | EMAC Receive Control Register0                 |
| EMAC_RX_CTL1          | 0x0028 | EMAC Receive Control Register1                 |
| EMAC_RX_DMA_DESC_LIST | 0x0034 | EMAC Receive Descriptor List Address Register  |
| EMAC_RX_FRM_FLT       | 0x0038 | EMAC Receive Frame Filter Register             |
| EMAC_RX_HASH0         | 0x0040 | EMAC Hash Table Register0                      |

| Register Name    | Offset                   | Description                                   |
|------------------|--------------------------|-----------------------------------------------|
| EMAC_RX_HASH1    | 0x0044                   | EMAC Hash Table Register1                     |
| EMAC_MII_CMD     | 0x0048                   | EMAC Management Interface Command Register    |
| EMAC_MII_DATA    | 0x004C                   | EMAC Management Interface Data Register       |
| EMAC_ADDR_HIGH0  | 0x0050                   | EMAC MAC Address High Register0               |
| EMAC_ADDR_LOW0   | 0x0054                   | EMAC MAC Address Low Register0                |
| EMAC_ADDR_HIGHN  | 0x0050+0x08*N<br>(N=1~7) | EMAC MAC Address High Register N (N=1~7)      |
| EMAC_ADDR_LOWN   | 0x0054+0x08*N<br>(N=1~7) | EMAC MAC Address Low Register N (N=1~7)       |
| EMAC_TX_DMA_STA  | 0x00B0                   | EMAC Transmit DMA Status Register             |
| EMAC_TX_CUR_DESC | 0x00B4                   | EMAC Current Transmit Descriptor Register     |
| EMAC_TX_CUR_BUF  | 0x00B8                   | EMAC Current Transmit Buffer Address Register |
| EMAC_RX_DMA_STA  | 0x00C0                   | EMAC Receive DMA Status Register              |
| EMAC_RX_CUR_DESC | 0x00C4                   | EMAC Current Receive Descriptor Register      |
| EMAC_RX_CUR_BUF  | 0x00C8                   | EMAC Current Receive Buffer Address Register  |
| EMAC_RGMII_STA   | 0x00D0                   | EMAC RGMII Status Register                    |

### 9.12.6 Register Description

#### 9.12.6.1 0x0000 EMAC Basic Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: EMAC_BASIC_CTL0                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31:4           | /          | /           | /                                                                                                 |
| 3:2            | R/W        | 0x0         | SPEED<br>EMAC Working Speed<br>00: 1000 Mbit/s<br>01: Reserved<br>10: 10 Mbit/s<br>11: 100 Mbit/s |
| 1              | R/W        | 0x0         | LOOPBACK<br>EMAC Loopback Mode For Test<br>0: Disable<br>1: Enable                                |

| Offset: 0x0000 |            |             | Register Name: EMAC_BASIC_CTL0                                   |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 0              | R/W        | 0x0         | DUPLEX<br>EMAC Transfer Mode<br>0: Half-duplex<br>1: Full-duplex |

#### 9.12.6.2 0x0004 EMAC Basic Control Register1 (Default Value: 0x0800\_0000)

| Offset: 0x0004 |            |             | Register Name: EMAC_BASIC_CTL1                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                       |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                 |
| 29:24          | R/W        | 0x8         | BURST_LEN<br>The burst length of RX and TX DMA transfer.                                                                                                                                                                                                          |
| 23:2           | /          | /           | /                                                                                                                                                                                                                                                                 |
| 1              | R/W        | 0x0         | RX_TX_PRI<br>RX TX DMA Priority<br>0: Same priority<br>1: RX priority is over TX                                                                                                                                                                                  |
| 0              | R/W        | 0x0         | SOFT_RST<br>Soft Reset all Registers and Logic<br>0: No valid<br>1: Reset<br>All clock inputs must be valid before soft reset. This bit is cleared internally when the reset operation is completed fully. Before writing any register, this bit should read a 0. |

#### 9.12.6.3 0x0008 EMAC Interrupt Status Register (Default Value: 0x4000\_0000)

| Offset: 0x0008 |            |             | Register Name: EMAC_INT_STA |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:17          | R          | 0x2000      | Reserved                    |

| Offset: 0x0008 |            |             | Register Name: EMAC_INT_STA                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                      |
| 16             | R/W1C      | 0x0         | <p>RGMII_LINK_STA_P<br/>RMII Link Status Changed Interrupt Pending<br/>0: No Pending<br/>1: Pending<br/>Write '1' to clear it.</p>                                                                                                                                                                                                                                                               |
| 15:<br>14      | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                |
| 13             | R/W1C      | 0x0         | <p>RX_EARLY_P<br/>RX DMA Filled First Data Buffer of the Receive Frame Interrupt Pending<br/>0: No Pending<br/>1: Pending<br/>Write '1' to clear it.</p>                                                                                                                                                                                                                                         |
| 12             | R/W1C      | 0x0         | <p>RX_OVERFLOW_P<br/>RX FIFO Overflow Error Interrupt Pending<br/>0: No Pending<br/>1: Pending<br/>Write '1' to clear it.</p>                                                                                                                                                                                                                                                                    |
| 11             | R/W1C      | 0x0         | <p>RX_TIMEOUT_P<br/>RX Timeout Interrupt Pending<br/>0: No Pending<br/>1: Pending<br/>Write '1' to clear it. When this bit is asserted, the length of the received frame is greater than 2048 bytes (10240 when JUMBO_FRM_EN is set)</p>                                                                                                                                                         |
| 10             | R/W1C      | 0x0         | <p>RX_DMA_STOPPED_P<br/>When this bit asserted, the RX DMA FSM is stopped.</p>                                                                                                                                                                                                                                                                                                                   |
| 9              | R/W1C      | 0x0         | <p>RX_BUF_UA_P<br/>RX Buffer UA Interrupt Pending<br/>0: No Pending<br/>1: Pending<br/>Write '1' to clear it. When this bit is asserted, the RX DMA cannot acquire the next RX descriptor and RX DMA FSM is suspended. The ownership of the next RX descriptor should be changed to RX DMA. The RX DMA FSM will resume when the RX_DMA_START is written or the next receive frame is coming.</p> |

| Offset: 0x0008 |            |             | Register Name: EMAC_INT_STA                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                    |
| 8              | R/W1C      | 0x0         | <p><b>RX_P</b><br/> Frame RX Completed Interrupt Pending<br/> 0: No Pending<br/> 1: Pending<br/> Write '1' to clear it. When this bit is asserted, a frame reception is completed. The RX DMA FSM remains running.</p>                                                                                                                         |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                              |
| 5              | R/W1C      | 0x0         | <p><b>TX_EARLY_P</b><br/> Total interrupt pending which the frame is transmitted to FIFO<br/> 0: No Pending<br/> 1: Pending<br/> Write '1' to clear it.</p>                                                                                                                                                                                    |
| 4              | R/W1C      | 0x0         | <p><b>TX_UNDERFLOW_P</b><br/> TX FIFO Underflow Interrupt Pending<br/> 0: No Pending<br/> 1: Pending<br/> Write '1' to clear it.</p>                                                                                                                                                                                                           |
| 3              | R/W1C      | 0x0         | <p><b>TX_TIMEOUT_P</b><br/> Transmitter Timeout Interrupt Pending<br/> 0: No Pending<br/> 1: Pending<br/> Write '1' to clear it.</p>                                                                                                                                                                                                           |
| 2              | R/W1C      | 0x0         | <p><b>TX_BUF_UA_P</b><br/> TX Buffer UA Interrupt Pending<br/> 0: No Pending<br/> 1: Pending<br/> When this asserted, the TX DMA can not acquire the next TX descriptor and the TX DMA FSM is suspended. The ownership of the next TX descriptor should be changed to TX DMA. The TX DMA FSM will resume when writing to TX_DMA_START bit.</p> |
| 1              | R/W1C      | 0x0         | <p><b>TX_DMA_STOPPED_P</b><br/> Transmission DMA Stopped Interrupt Pending<br/> 0: No Pending<br/> 1: Pending<br/> Write '1' to clear it.</p>                                                                                                                                                                                                  |

| Offset: 0x0008 |            |             | Register Name: EMAC_INT_STA                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 0              | R/W1C      | 0x0         | <p>TX_P</p> <p>Frame Transmission Interrupt Pending</p> <p>0: No Pending</p> <p>1: Pending</p> <p>Write '1' to clear it.</p> |

#### 9.12.6.4 0x000C EMAC Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: EMAC_INT_EN                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:14          | /          | /           | /                                                                                                        |
| 13             | R/W        | 0x0         | <p>RX_EARLY_INT_EN</p> <p>Early Receive Interrupt</p> <p>0: Disable</p> <p>1: Enable</p>                 |
| 12             | R/W        | 0x0         | <p>RX_OVERFLOW_INT_EN</p> <p>Receive Overflow Interrupt</p> <p>0: Disable</p> <p>1: Enable</p>           |
| 11             | R/W        | 0x0         | <p>RX_TIMEOUT_INT_EN</p> <p>Receive Timeout Interrupt</p> <p>0: Disable</p> <p>1: Enable</p>             |
| 10             | R/W        | 0x0         | <p>RX_DMA_STOPPED_INT_EN</p> <p>Receive DMA FSM Stopped Interrupt</p> <p>0: Disable</p> <p>1: Enable</p> |
| 9              | R/W        | 0x0         | <p>RX_BUF_UA_INT_EN</p> <p>Receive Buffer Unavailable Interrupt</p> <p>0: Disable</p> <p>1: Enable</p>   |
| 8              | R/W        | 0x0         | <p>RX_INT_EN</p> <p>Receive Interrupt</p> <p>0: Disable</p> <p>1: Enable</p>                             |
| 7:6            | /          | /           | /                                                                                                        |

| Offset: 0x000C |            |             | Register Name: EMAC_INT_EN                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 5              | R/W        | 0x0         | <p>TX_EARLY_INT_EN<br/>Early Transmit Interrupt<br/>0: Disable<br/>1: Enable</p>                 |
| 4              | R/W        | 0x0         | <p>TX_UNDERFLOW_INT_EN<br/>Transmit Underflow Interrupt<br/>0: Disable<br/>1: Enable</p>         |
| 3              | R/W        | 0x0         | <p>TX_TIMEOUT_INT_EN<br/>Transmit Timeout Interrupt<br/>0: Disable<br/>1: Enable</p>             |
| 2              | R/W        | 0x0         | <p>TX_BUF_UA_INT_EN<br/>Transmit Buffer Available Interrupt<br/>0: Disable<br/>1: Enable</p>     |
| 1              | R/W        | 0x0         | <p>TX_DMA_STOPPED_INT_EN<br/>Transmit DMA FSM Stopped Interrupt<br/>0: Disable<br/>1: Enable</p> |
| 0              | R/W        | 0x0         | <p>TX_INT_EN<br/>Transmit Interrupt<br/>0: Disable<br/>1: Enable</p>                             |

#### 9.12.6.5 0x0010 EMAC Transmit Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: EMAC_TX_CTL0                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31             | R/W        | 0x0         | <p>TX_EN<br/>Enable Transmitter<br/>0: Disable<br/>1: Enable<br/>When disabled, the transmission will continue until the current transmission finishes.</p> |

| Offset: 0x0010 |            |             | Register Name: EMAC_TX_CTL0                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
| 30             | R/W        | 0x0         | <p>TX_FRM_LEN_CTL</p> <p>Frame Transmit Length Control</p> <p>0: Up to 2,048 bytes (JUMBO_FRM_EN==0)</p> <p>Up to 10,240 bytes (JUMBO_FRM_EN==1)</p> <p>1: Up to 16,384 bytes</p> <p>Any bytes after that is cut off.</p> |
| 29:0           | /          | /           | /                                                                                                                                                                                                                         |

#### 9.12.6.6 0x0014 EMAC Transmit Control Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: EMAC_TX_CTL1                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x0         | <p>TX_DMA_START</p> <p>Transmit DMA FSM Start</p> <p>0: No valid</p> <p>1: Start</p> <p>It is cleared internally and always read a 0.</p>                                                                                                                                                                                                                     |
| 30             | R/W        | 0x0         | <p>TX_DMA_EN</p> <p>0: Stop TX DMA after the completion of current frame transmission</p> <p>1: Start and run TX DMA</p>                                                                                                                                                                                                                                      |
| 29:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                             |
| 10:8           | R/W        | 0x0         | <p>TX_TH</p> <p>Threshold value of TX DMA FIFO</p> <p>When TX_MD is 0, the transmission starts when the frame size in TX DMA FIFO is greater than the threshold. In addition, the full frames with a length less than the threshold are transferred automatically.</p> <p>000: 64</p> <p>001: 128</p> <p>010: 192</p> <p>011: 256</p> <p>Others: Reserved</p> |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                             |

| Offset: 0x0014 |            |             | Register Name: EMAC_TX_CTL1                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 1              | R/W        | 0x0         | <p>TX_MD</p> <p>Transmission Mode</p> <p>0: TX starts after the TX DMA FIFO bytes is greater than the TX_TH</p> <p>1: TX starts after the TX DMA FIFO is located a full frame</p> |
| 0              | R/WAC      | 0x0         | <p>FLUSH_TX_FIFO</p> <p>Flush the data in the TX FIFO</p> <p>0: Enable</p> <p>1: Disable</p>                                                                                      |

#### 9.12.6.7 0x001C EMAC Transmit Flow Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: EMAC_TX_FLOW_CTL                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x0         | <p>TX_FLOW_CTL_STA</p> <p>This bit indicates a pause frame transmission is in progress. When the configuration of flow control is ready, set this bit to transmit a pause frame in full-duplex mode or activate the backpressure function. After the transmission is completed, this bit will be cleared automatically. Before writing TX_FLOW_CTRL register, this bit must be read as 0.</p> |
| 30:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                             |
| 21:20          | R/W        | 0x0         | <p>TX_PAUSE_FRM_SLOT</p> <p>The threshold of the pause timer at which the input flow control signal is checked for automatic re-transmission of the pause frame. The threshold values should be always less than PAUSE_TIME.</p>                                                                                                                                                              |
| 19:4           | R/W        | 0x0         | <p>PAUSE_TIME</p> <p>The pause time field in the transmitted control frame.</p>                                                                                                                                                                                                                                                                                                               |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                             |
| 1              | R/W        | 0x0         | <p>ZQP_FRM_EN</p> <p>0: Disable</p> <p>1: Enable</p> <p>When set, enable the functionality to generate the Zero-Quanta Pause control frame.</p>                                                                                                                                                                                                                                               |

| Offset: 0x001C |            |             | Register Name: EMAC_TX_FLOW_CTL                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                           |
| 0              | R/W        | 0x0         | <p>TX_FLOW_CTL_EN<br/>TX Flow Control Enable<br/>0: Disable<br/>1: Enable</p> <p>When set, enable flow control operation to transmit pause frames in full-duplex mode, or enable the back-pressure operation in half-duplex mode.</p> |

#### 9.12.6.8 0x0020 EMAC Transmit DMA Descriptor List Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: EMAC_TX_DMA_LIST                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:0           | R/W        | 0x0         | <p>TX_DESC_LIST<br/>The base address of the transmission descriptor list<br/>It must be 32-bit aligned.</p> |

#### 9.12.6.9 0x0024 EMAC Receive Control Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: EMAC_RX_CTL0                                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                           |
| 31             | R/W        | 0x0         | <p>RX_EN<br/>Enable Receiver<br/>0: Disable receiver after current reception<br/>1: Enable</p>                                                                                                        |
| 30             | R/W        | 0x0         | <p>RX_FRM_LEN_CTL<br/>Frame Receive Length Control<br/>0: Up to 2048 bytes (JUMBO_FRM_EN==0)<br/>Up to 10240 bytes (JUMBO_FRM_EN==1)<br/>1: Up to 16384 bytes<br/>Any bytes after that is cut off</p> |
| 29             | R/W        | 0x0         | <p>JUMBO_FRM_EN<br/>Jumbo Frame Enable<br/>0: Disable<br/>1: Enable Jumbo frames of 9018 bytes without reporting a giant</p>                                                                          |

| Offset: 0x0024 |            |             | Register Name: EMAC_RX_CTL0                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                             |
| 28             | R/W        | 0x0         | STRIP_FCS<br>When set, strip the Pad/FCS field on received frames only when the length of field value is less than or equal to 1500 bytes.                                                                                                                                                              |
| 27             | R/W        | 0x0         | CHECK_CRC<br>Check CRC Enable<br>0: Disable<br>1: Calculate CRC and check the IPv4 Header Checksum                                                                                                                                                                                                      |
| 26:18          | /          | /           | /                                                                                                                                                                                                                                                                                                       |
| 17             | R/W        | 0x0         | RX_PAUSE_FRM_MD<br>0: Only detect multicast pause frame specified in the 802.3x standard.<br>1: In addition to detect multicast pause frame specified in the 802.3x standard, also detect unicast pause frame with the address specified in MAC Address 0 High Register and MAC address 0 Low Register. |
| 16             | R/W        | 0x0         | RX_FLOW_CTL_EN<br>When set, enable the functionality that decodes the received pause frame and disable its transmitter for a specified time by pause frame.                                                                                                                                             |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                       |

#### 9.12.6.10 0x0028 EMAC Receive Control Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: EMAC_RX_CTL1                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                             |
| 31             | R/W        | 0x0         | RX_DMA_START<br>When set, the RX DMA will work. It is cleared internally and always read a 0.                           |
| 30             | R/W        | 0x0         | RX_DMA_EN<br>Receive DMA Enable<br>0: Stop RX DMA after finishing the received current frame<br>1: Start and run RX DMA |
| 29:25          | /          | /           | /                                                                                                                       |

| Offset: 0x0028 |            |             | Register Name: EMAC_RX_CTL1                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
| 24             | R/W        | 0x0         | <p>RX_FIFO_FLOW_CTL<br/>Receive FIFO Flow Control Enable<br/>0: Disable<br/>1: Enable, base on RX_FLOW_CTL_TH_DEACT and RX_FLOW_CTL_TH_ACT</p>                                                                                   |
| 23:22          | R/W        | 0x0         | <p>RX_FLOW_CTL_TH_DEACT<br/>Threshold for Deactivating Flow Control<br/>00: Full minus 1 KB<br/>01: Full minus 2 KB<br/>10: Full minus 3 KB<br/>11: Full minus 4 KB<br/>Valid in both half-duplex mode and full-duplex mode.</p> |
| 21:20          | R/W        | 0x0         | <p>RX_FLOW_CTL_TH_ACT<br/>Threshold for Activating Flow Control<br/>00: Full minus 1 KB<br/>01: Full minus 2 KB<br/>10: Full minus 3 KB<br/>11: Full minus 4 KB<br/>Valid in both half-duplex mode and full-duplex mode.</p>     |
| 19:6           | /          | /           | /                                                                                                                                                                                                                                |
| 5:4            | R/W        | 0x0         | <p>RX_TH<br/>Threshold for RX DMA FIFO Start<br/>00: 64<br/>01: 32<br/>10: 96<br/>11: 128<br/>Only valid when RX_MD == 0, the full frames with a length less than the threshold are transferred automatically.</p>               |
| 3              | R/W        | 0x0         | <p>RX_ERR_FRM<br/>0: RX DMA drops frames with error<br/>1: RX DMA forwards frames with error</p>                                                                                                                                 |
| 2              | R/W        | 0x0         | <p>RX_RUNT_FRM<br/>When the bit is set to 1, it indicates forward undersized frames with no error and length less than 64 bytes.</p>                                                                                             |

| Offset: 0x0028 |            |             | Register Name: EMAC_RX_CTL1                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 1              | R/W        | 0x0         | <p>RX_MD</p> <p>Receive Mode</p> <p>0: RX starts to read after the RX DMA FIFO byte is greater than RX_TH</p> <p>1: RX starts to read after the RX DMA FIFO is located a full frame</p> |
| 0              | R/W        | 0x0         | <p>FLUSH_RX_FRM</p> <p>Flush Receive Frames</p> <p>0: Enable when the receive descriptors/buffers are unavailable</p> <p>1: Disable</p>                                                 |

#### 9.12.6.11 0x0034 EMAC Receive DMA Descriptor List Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: EMAC_RX_DMA_LIST                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31:0           | R/W        | 0x0         | <p>RX_DESC_LIST</p> <p>The base address of the received descriptor list</p> <p>It must be 32-bit aligned.</p> |

#### 9.12.6.12 0x0038 EMAC Receive Frame Filter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: EMAC_RX_FRM_FLT                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31             | R/W        | 0x0         | <p>DIS_ADDR_FILTER</p> <p>Disable Address Filter</p> <p>0: Enable</p> <p>1: Disable</p>                                               |
| 30:18          | /          | /           | /                                                                                                                                     |
| 17             | R/W        | 0x0         | <p>DIS_BROADCAST</p> <p>Disable Receive Broadcast Frames</p> <p>0: Receive</p> <p>1: Drop</p>                                         |
| 16             | R/W        | 0x0         | <p>RX_ALL_MULTICAST</p> <p>Receive All Multicast Frames Filter</p> <p>0: Filter according to HASH_MULTICAST</p> <p>1: Receive all</p> |

| Offset: 0x0038 |            |             | Register Name: EMAC_RX_FRM_FLT                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                     |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                               |
| 13:12          | R/W        | 0x0         | <p>CTL_FRM_FILTER<br/>Receive Control Frames Filter<br/>00: Drop all control frames<br/>01: Drop all control frames<br/>10: Receive all control frames<br/>11: Receive all control frames when passing the address filter</p>                                                   |
| 11:10          | /          | /           | /                                                                                                                                                                                                                                                                               |
| 9              | R/W        | 0x0         | <p>HASH_MULTICAST<br/>Filter Multicast Frames Set<br/>0: By comparing the DA field in DA MAC address registers<br/>1: According to the hash table</p>                                                                                                                           |
| 8              | R/W        | 0x0         | <p>HASH_UNICAST<br/>Filter Unicast Frames Set<br/>0: By comparing the DA field in DA MAC address registers<br/>1: According to the hash table</p>                                                                                                                               |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                               |
| 6              | R/W        | 0x0         | <p>SA_FILTER_EN<br/>Receive SA Filter Enable<br/>0: Receive frames and update the result of SA filter<br/>1: Update the result of the SA filter. In addition, if the SA field of the received frame does not match the values in SA MAC address registers, drop this frame.</p> |
| 5              | R/W        | 0x0         | <p>SA_INV_FILTER<br/>Receive SA Invert Filter Set<br/>0: Pass frames whose SA field matches SA MAC address registers<br/>1: Pass frames whose SA field does not match SA MAC address registers</p>                                                                              |
| 4              | R/W        | 0x0         | <p>DA_INV_FILTER<br/>0: Normal filtering of frames is performed<br/>1: Filter both unicast and multicast frames by comparing DA field in inverse filtering mode</p>                                                                                                             |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                               |

| Offset: 0x0038 |            |             | Register Name: EMAC_RX_FRM_FLT                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                       |
| 1              | R/W        | 0x0         | FLT_MD<br>0: If the HASH_MULTICAST or HASH_UNICAST is set, the frame is passed only when it matches the Hash filter<br>1: Receive the frame when it passes the address register filter or the hash filter (set by HASH_MULTICAST or HASH_UNICAST) |
| 0              | R/W        | 0x0         | RX_ALL<br>Receive All Frame<br>0: Receive the frames that pass the SA/DA address filter<br>1: Receive all frames and update the result of address filter (pass or fail) in the receive status word                                                |

#### 9.12.6.13 0x0040 EMAC Receive Hash Table Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: EMAC_RX_HASH0                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:0           | R/W        | 0x0         | HASH_TAB0<br>The upper 32 bits of Hash table for the received frame filter. |

#### 9.12.6.14 0x0044 EMAC Receive Hash Table Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: EMAC_RX_HASH1                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:0           | R/W        | 0x0         | HASH_TAB1<br>The lower 32 bits of Hash table for the received frame filter. |

#### 9.12.6.15 0x0048 EMAC MII Command Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: EMAC_MII_CMD |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:23          | /          | /           | /                           |

| Offset: 0x0048 |            |             | Register Name: EMAC_MII_CMD                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 22:20          | R/W        | 0x0         | MDC_DIV_RATIO_M<br>MDC Clock Divider Ratio<br>The MDC Clock is divided from the AHB clock.<br>000: 16<br>001: 32<br>010: 64<br>011: 128<br>Others: Reserved                                     |
| 19:17          | /          | /           | /                                                                                                                                                                                               |
| 16:12          | R/W        | 0x0         | PHY_ADDR<br>PHY Address                                                                                                                                                                         |
| 11:9           | /          | /           | /                                                                                                                                                                                               |
| 8:4            | R/W        | 0x0         | PHY_REG_ADDR<br>PHY Register Address                                                                                                                                                            |
| 3:2            | /          | /           | /                                                                                                                                                                                               |
| 1              | R/W        | 0x0         | MII_WR<br>MII Write and Read<br>0: Read<br>1: Write                                                                                                                                             |
| 0              | R/WAC      | 0x0         | MII_BUSY<br>MII Status<br>0: Writing 0 is no valid, and reading 0 indicates the read/write operation is finished<br>1: Writing 1 starts the read/write operation, and reading 1 indicates busy. |

#### 9.12.6.16 0x004C EMAC MII Data Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: EMAC_MII_DATA                                        |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
| 31:16          | /          | /           | /                                                                   |
| 15:0           | R/W        | 0x0         | MII_DATA<br>Write to or read from the register in the selected PHY. |

### 9.12.6.17 0x0050 EMAC MAC Address High Register0 (Default Value: 0x0000\_FFFF)

| Offset: 0x0050 |            |             | Register Name: EMAC_ADDR_HIGH0                              |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:16          | /          | /           | /                                                           |
| 15:0           | R/W        | 0xFFFF      | MAC_ADDR_HIGH0<br>The upper 16 bits of the 1st MAC address. |

### 9.12.6.18 0x0054 EMAC MAC Address Low Register0 (Default Value: 0xFFFF\_FFFF)

| Offset: 0x0054 |            |             | Register Name: EMAC_ADDR_LOW0                          |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:0           | R/W        | 0xFFFFFFFF  | MAC_ADDR_LOW0<br>The lower 32 bits of 1st MAC address. |

### 9.12.6.19 0x0050+0x08\*N EMAC MAC Address High Register N (Default Value: 0x0000\_FFFF)

| Offset: 0x0050+0x08*N (N=1~7) |            |             | Register Name: EMAC_ADDR_HIGHN                                                                                                                                                            |
|-------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                                                                                                                                               |
| 31                            | R/W        | 0x0         | MAC_ADDR_CTL<br>MAC Address Valid<br>0: Not valid<br>1: Valid                                                                                                                             |
| 30                            | R/W        | 0x0         | MAC_ADDR_TYPE<br>MAC Address Type<br>0: Used to compare with the destination address of the received frame<br>1: Used to compare with the source address of the received frame            |
| 29:24                         | R/W        | 0x0         | MAC_ADDR_BYT_CTRL<br>MAC Address Byte Control Mask<br>The lower bit of mask controls the lower byte of the MAC address. When the bit of mask is 1, do not compare the corresponding byte. |
| 23:16                         | /          | /           | /                                                                                                                                                                                         |
| 15:0                          | R/W        | 0xFFFF      | MAC_ADDR_HIGH<br>The upper 16 bits of the MAC address.                                                                                                                                    |

### 9.12.6.20 0x0054+0x08\*N EMAC MAC Address Low Register N (Default Value: 0x0000\_0000)

| Offset: 0x0054+0x08*N (N=1~7) |            |             | Register Name: EMAC_ADDR_LOWN                                 |
|-------------------------------|------------|-------------|---------------------------------------------------------------|
| Bit                           | Read/Write | Default/Hex | Description                                                   |
| 31:0                          | R/W        | 0x0         | MAC_ADDR_LOWN<br>The lower 32 bits of MAC address N (N: 1~7). |

### 9.12.6.21 0x00B0 EMAC Transmit DMA Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: EMAC_TX_DMA_STA                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2:0            | R          | 0x0         | <p>TX_DMA_STA<br/>The State of Transmit DMA FSM</p> <p>000: STOP, when reset or disable TX DMA</p> <p>001: RUN_FETCH_DESC, fetching TX DMA descriptor</p> <p>010: RUN_WAIT_STA, waiting for the status of TX frame</p> <p>011: RUN_TRANS_DATA, passing the frame from host memory to TX DMA FIFO</p> <p>100: Reserved</p> <p>101: Reserved</p> <p>111: RUN_CLOSE_DESC, closing TX descriptor</p> <p>110: SUSPEND, TX descriptor is unavailable or TX DMA FIFO underflow</p> |

### 9.12.6.22 0x00B4 EMAC Transmit DMA Current Descriptor Register (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: EMAC_TX_DMA_CUR_DESC                            |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:0           | R          | 0x0         | TX_DMA_CUR_DESC<br>The address of current transmit descriptor. |

### 9.12.6.23 0x00B8 EMAC Transmit DMA Current Buffer Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00B8 |            |             | Register Name: EMAC_TX_DMA_CUR_BUF                            |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:0           | R          | 0x0         | TX_DMA_CUR_BUF<br>The address of current transmit DMA buffer. |

### 9.12.6.24 0x00C0 EMAC Receive DMA Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: EMAC_RX_DMA_STA                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                             |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                       |
| 2:0            | R          | 0x0         | RX_DMA_STA<br>The State of RX DMA FSM<br>000: STOP, when reset or disable RX DMA<br>001: RUN_FETCH_DESC, fetching RX DMA descriptor<br>010: Reserved<br>011: RUN_WAIT_FRM, waiting for the frame<br>100: SUSPEND, RX descriptor is unavailable<br>101: RUN_CLOSE_DESC, closing RX descriptor<br>110: Reserved<br>111: RUN_TRANS_DATA, passing the frame from host memory to RX DMA FIFO |

### 9.12.6.25 0x00C4 EMAC Receive DMA Current Descriptor Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: EMAC_RX_DMA_CUR_DESC                          |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:0           | R          | 0x0         | RX_DMA_CUR_DESC<br>The address of current receive descriptor |

### 9.12.6.26 0x00C8 EMAC Receive DMA Current Buffer Address Register (Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: EMAC_RX_DMA_CUR_BUF                          |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:0           | R          | 0x0         | RX_DMA_CUR_BUF<br>The address of current receive DMA buffer |

### 9.12.6.27 0x00D0 EMAC RGMII Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00D0 |            |             | Register Name: EMAC_RGMII_STA                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:4           | /          | /           | /                                                                                                                          |
| 3              | R          | 0x0         | <b>RGMII_LINK</b><br>The link status of the RGMII interface<br>0: Down<br>1: Up                                            |
| 2:1            | R          | 0x0         | <b>RGMII_LINK_SPD</b><br>The link speed of the RGMII interface<br>00: 2.5 MHz<br>01: 25 MHz<br>10: 125 MHz<br>11: Reserved |
| 0              | R          | 0x0         | <b>RGMII_LINK_MD</b><br>The link mode of the RGMII interface<br>0: Half-Duplex<br>1: Full-Duplex                           |

## 9.13 CIR Receiver

### 9.13.1 Overview

The Consumer Infrared receiver (CIR\_RX) captures pulse from the IR Receiver module and uses the Run-Length Code (RLC) to encode the pulse.

The CIR receiver has the following features:

- Supports CIR remote control receiver
- Supports NEC IR protocol
- 64x8 bits RX FIFO for data buffer
- Programmable RX FIFO thresholds
- Supports interrupt
- Sample clock up to 1 MHz

### 9.13.2 Block Diagram

Figure 9-106 CIR\_RX Block Diagram



The CIR\_RX samples the input signal on the programmable frequency and records these samples into RX FIFO when one CIR signal is found on the air. The CIR\_RX uses Run-Length Code (RLC) to encode pulse width. The encoded data is buffered in 64 levels and 8-bit width RX FIFO; the MSB bit is used to record the polarity of the receiving CIR signal, the rest 7 bits are used for the length of RLC. The maximum length of the RLC is 128. If the duration of one level (high or low level) is more than 128, another byte is used.

### 9.13.3 Functional Description

#### 9.13.3.1 External Signals

The following table describes the external signals of CIR\_RX.

**Table 9-40 CIR\_RX External Signals**

| Signal | Description                | Type |
|--------|----------------------------|------|
| IR-RX  | Consumer Infrared Receiver | I    |

#### 9.13.3.2 Clock Sources

**Figure 9-107 CIR\_RX Clock System**



#### 9.13.3.3 Typical Application

**Figure 9-108 CIR\_RX Application Diagram**



### 9.13.3.4 NEC Protocol Format

Figure 9-109 NEC Protocol



The CIR\_RX module is a timer with a capture function.

When CIR\_RX signals satisfy the Active Threshold (ATHR), the CIR receiver can start to capture. In the process, the signal is ignored if the pulse width of the signal is less than NTHR. When CIR\_RX signals satisfy ITHR (Idle Threshold), the capture process is stopped and the Receiver Packet End interrupt is generated, then the Receiver Packet End Flag is asserted.

In a capture process, every effective pulse is buffered to FIFO in bytes according to the form of the Run-Length Code. The MSB bit of a byte is the polarity of pulse, and the rest 7 bits is pulse width by taking Sample Clock as a basic unit. This is the code form of the RLC-Byte. When the level changes or the pulse width counter overflows, the RLC-Byte is buffered to FIFO. The CIR\_RX module receives the infrared signals transmitted by the infrared remote control, the software decodes the signals.

### 9.13.3.5 Operating Mode

#### Sample Clock

Figure 9-110 Logical '0' and Logical '1' of NEC Protocol



For NEC protocol, a logical "1" takes 2.25 ms (560 us+1680 us) to transmit, while a logical "0" is only half of that, being 1.12 ms (560 us+560 us).

For example, if the sample clock is 31.25 kHz, a sample cycle is 32 us, then 18 sample cycles are 560 us. So the RLC of 560 us low level is 0x12 (b'00010010), the RLC of 560 us high level is 0x92 (b'10010010). Then a logical "1" takes code 0x12 (b'00010010) and code 0xb5 (b'10110101) to transmit, a logical "0" takes code 0x12 and code 0x92 to transmit.

### Active Threshold (ATHR)

When the CIR\_RX is in Idle state, if the electrical level of the CIR\_RX signal changes (positive jump or negative jump), and the duration reaches this threshold, then the CIR\_RX takes the starting of the signal as a lead code, and the CIR\_RX turns into an active state and starts to capture CIR\_RX signals.

Figure 9-111 ATHR Definition



### Idle Threshold (ITHR)

If the electrical level of CIR\_RX signals has no change, and the duration reaches this threshold, then the CIR\_RX enters into Idle state and ends this capture.

Figure 9-112 ITHR Definition



### Noise Threshold (NTHR)

In the capture process, the pulse is ignored if the pulse width is less than the Noise Threshold.

Figure 9-113 NTHR Definition



### Active Pulse Accept Mode (APAM)

The APAM is used to fit the type of lead code. If a pulse does not fit the type of lead code, it is not regarded as a lead code even if the pulse width reaches ATHR.

Figure 9-114 APAM Definition



#### 9.13.4 Programming Guidelines

Figure 9-115 CIR Receiver Process



### 9.13.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| CIR_RX      | 0x07040000   |

| Register Name | Offset | Description                             |
|---------------|--------|-----------------------------------------|
| CIR_CTL       | 0x0000 | CIR Control Register                    |
| CIR_RXPCFG    | 0x0010 | CIR Receiver Pulse Configure Register   |
| CIR_RXFIFO    | 0x0020 | CIR Receiver FIFO Register              |
| CIR_RXINT     | 0x002C | CIR Receiver Interrupt Control Register |
| CIR_RXSTA     | 0x0030 | CIR Receiver Status Register            |
| CIR_RXCFG     | 0x0034 | CIR Receiver Configure Register         |

### 9.13.6 Register Description

#### 9.13.6.1 0x0000 CIR Receiver Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CIR_CTL                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                           |
| 31:8           | /          | /           | /                                                                                                                                                                                                                     |
| 7:6            | R/W        | 0x0         | APAM<br>Active Pulse Accept Mode<br>00, 01: Both positive and negative pulses are valid as a leading code<br>10: Only negative pulse is valid as a leading code<br>11: Only positive pulse is valid as a leading code |
| 5:4            | R/W        | 0x0         | CIR ENABLE<br>00–10: Reserved<br>11: CIR mode enable                                                                                                                                                                  |
| 3:2            | /          | /           | /                                                                                                                                                                                                                     |
| 1              | R/W        | 0x0         | RXEN<br>Receiver Block Enable<br>0: Disable<br>1: Enable                                                                                                                                                              |

| Offset: 0x0000 |            |             | Register Name: CIR_CTL                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 0              | R/W        | 0x0         | <p>GEN<br/>Global Enable<br/>A disable on this bit overrides any other block or channel enables and flushes all FIFOs.<br/>0: Disable<br/>1: Enable</p> |

#### 9.13.6.2 0x0010 CIR Receiver Pulse Configure Register (Default Value: 0x0000\_0004)

| Offset: 0x0010 |            |             | Register Name: CIR_RXPCFG                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                       |
| 31:3           | /          | /           | /                                                                                                                 |
| 2              | R/W        | 0x1         | <p>RPPI<br/>Receiver Pulse Polarity Invert<br/>0: Do not invert receiver signal<br/>1: Invert receiver signal</p> |
| 1:0            | /          | /           | /                                                                                                                 |

#### 9.13.6.3 0x0020 CIR Receiver FIFO Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CIR_RXFIFO         |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31:8           | /          | /           | /                                 |
| 7:0            | R          | 0x0         | <p>RBF<br/>Receiver Byte FIFO</p> |

#### 9.13.6.4 0x002C CIR Receiver Interrupt Control Register (Default Value: 0x0000\_0000)

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

| Offset: 0x002C |            |             | Register Name: CIR_RXINT                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 13:8           | R/W        | 0x0         | <p>RAL</p> <p>RX FIFO available received byte level for interrupt and DMA request</p> <p>TRIGGER_LEVEL = RAL + 1</p>                                                                                                         |
| 5              | R/W        | 0x0         | <p>DRQ_EN</p> <p>RX FIFO DMA Enable</p> <p>0: Disable</p> <p>1: Enable</p> <p>When it is set to '1', the Receiver FIFO DRQ is asserted if reaching RAL. The DRQ is de-asserted when the condition fails.</p>                 |
| 4              | R/W        | 0x0         | <p>RAI_EN</p> <p>RX FIFO Available Interrupt Enable</p> <p>0: Disable</p> <p>1: Enable</p> <p>When it is set to '1', the Receiver FIFO IRQ is asserted if reaching RAL. The IRQ is de-asserted when the condition fails.</p> |
| 3:2            | /          | /           | /                                                                                                                                                                                                                            |
| 1              | R/W        | 0x0         | <p>RPEI_EN</p> <p>Receiver Packet End Interrupt Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                                |
| 0              | R/W        | 0x0         | <p>ROI_EN</p> <p>Receiver FIFO Overrun Interrupt Enable</p> <p>0: Disable</p> <p>1: Enable</p>                                                                                                                               |

#### 9.13.6.5 0x0030 CIR Receiver Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CIR_RXSTA |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:15          | /          | /           | /                        |

| Offset: 0x0030 |            |             | Register Name: CIR_RXSTA                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                            |
| 14:8           | R          | 0x0         | <p>RAC</p> <p>RX FIFO Available Counter</p> <p>0: No available data in RX FIFO</p> <p>1: 1-byte available data in RX FIFO</p> <p>2: 2-bytes available data in RX FIFO</p> <p>...</p> <p>64: 64-bytes available data in RX FIFO</p>                                                                                     |
| 7              | R          | 0x0         | <p>STAT</p> <p>Status of CIR</p> <p>0: Idle</p> <p>1: Busy</p>                                                                                                                                                                                                                                                         |
| 6:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                      |
| 4              | R/W1C      | 0x0         | <p>RA</p> <p>RX FIFO Available</p> <p>0: RX FIFO not available according to its level</p> <p>1: RX FIFO available according to its level</p> <p>Writing 1 clears this bit.</p>                                                                                                                                         |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                                                                                      |
| 1              | R/W1C      | 0x0         | <p>RPE</p> <p>Receiver Packet End Flag</p> <p>0: STO was not detected. In CIR mode, one CIR symbol is receiving or not detected.</p> <p>1: STO field or packet abort symbol (7'b0000,000 and 8'b0000,0000 for MIR and FIR) is detected. In CIR mode, one CIR symbol is received.</p> <p>Writing 1 clears this bit.</p> |
| 0              | R/W1C      | 0x0         | <p>ROI</p> <p>Receiver FIFO Overrun</p> <p>0: Receiver FIFO not overrun</p> <p>1: Receiver FIFO overrun</p> <p>Writing 1 clears this bit.</p>                                                                                                                                                                          |

**9.13.6.6 0x0034 CIR Receiver Configure Register (Default Value: 0x0000\_1828)**

| Offset: 0x0034 |            |             | Register Name: CIR_RXCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 24             | R/W        | 0x0         | SCS2<br>Bit2 of Sample Clock Select for CIR<br>This bit is defined by SCS bits below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 23             | R/W        | 0x0         | ATHC<br>Active Threshold Control for CIR<br>0: ATHR in a unit of (Sample Clock)<br>1: ATHR in a unit of (128*Sample Clocks)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 22:16          | R/W        | 0x0         | ATHR<br>Active Threshold for CIR<br>These bits control the duration of CIR from the idle to the active state. The duration can be calculated by ((ATHR + 1)*(ATHC? Sample Clock: 128*Sample Clock)).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:8           | R/W        | 0x18        | ITHR<br>Idle Threshold for CIR<br>The Receiver uses it to decide whether the CIR command is received. If there is no CIR signal on the air, the receiver is staying in IDLE status. One active pulse will bring the receiver from IDLE status to Receiving status. After the CIR receiver ends, the inputting signal will keep the specified level (high or low level) for a long time. The receiver can use this idle signal duration to decide that it has received the CIR command. The corresponding flag is asserted. If the corresponding interrupt is enabled, the interrupt line is asserted to the CPU.<br>When the duration of the signal keeps one status (high or low level) for the specified duration ((ITHR + 1)*128 sample_clk), this means that the previous CIR command is finished. |

| Offset: 0x0034 |            |             | Register Name: CIR_RXCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------|--------|--------------|---|---|---|------------|---|---|---|-------------|---|---|---|-------------|---|---|---|-------------|---|---|---|---------|---|---|---|----------|---|---|---|----------|---|---|---|----------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 7:2            | R/W        | 0xA         | <p>NTHR<br/>Noise Threshold for CIR<br/>When the duration of the signal pulse (high or low level) is less than NTHR, the pulse is taken as noise and should be discarded by hardware.</p> <p>0: All samples are recorded into RX FIFO<br/>1: If the signal is only one sample duration, it is taken as noise and discarded.<br/>2: If the signal is less than (<math>\leq</math>) two sample duration, it is taken as noise and discarded.<br/>...<br/>61: If the signal is less than (<math>\leq</math>) sixty-one sample duration, it is taken as noise and discarded.</p>                                                                           |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 1:0            | R/W        | 0x0         | <p>SCS<br/>Sample Clock Select for CIR</p> <table border="1"><thead><tr><th>SCS2</th><th>SCS[1]</th><th>SCS[0]</th><th>Sample Clock</th></tr></thead><tbody><tr><td>0</td><td>0</td><td>0</td><td>CIR_CLK/64</td></tr><tr><td>0</td><td>0</td><td>1</td><td>CIR_CLK/128</td></tr><tr><td>0</td><td>1</td><td>0</td><td>CIR_CLK/256</td></tr><tr><td>0</td><td>1</td><td>1</td><td>CIR_CLK/512</td></tr><tr><td>1</td><td>0</td><td>0</td><td>CIR_CLK</td></tr><tr><td>1</td><td>0</td><td>1</td><td>Reserved</td></tr><tr><td>1</td><td>1</td><td>0</td><td>Reserved</td></tr><tr><td>1</td><td>1</td><td>1</td><td>Reserved</td></tr></tbody></table> | SCS2 | SCS[1] | SCS[0] | Sample Clock | 0 | 0 | 0 | CIR_CLK/64 | 0 | 0 | 1 | CIR_CLK/128 | 0 | 1 | 0 | CIR_CLK/256 | 0 | 1 | 1 | CIR_CLK/512 | 1 | 0 | 0 | CIR_CLK | 1 | 0 | 1 | Reserved | 1 | 1 | 0 | Reserved | 1 | 1 | 1 | Reserved |
| SCS2           | SCS[1]     | SCS[0]      | Sample Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 0              | 0          | 0           | CIR_CLK/64                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 0              | 0          | 1           | CIR_CLK/128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 0              | 1          | 0           | CIR_CLK/256                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 0              | 1          | 1           | CIR_CLK/512                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 1              | 0          | 0           | CIR_CLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 1              | 0          | 1           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 1              | 1          | 0           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |
| 1              | 1          | 1           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |        |        |              |   |   |   |            |   |   |   |             |   |   |   |             |   |   |   |             |   |   |   |         |   |   |   |          |   |   |   |          |   |   |   |          |

## 9.14 CIR Transmitter

### 9.14.1 Overview

The CIR transmitter (CIR\_TX) can transfer arbitrary waves which can be modulated with configurable carrier waves such as 38 kHz.

The CIR\_TX has the following features:

- Supports CIR remote control transmitter
- 128 bytes FIFO for data buffer
- Configurable carrier frequency
- Supports Interrupt and DMA
- Supports handshake mode and waiting mode of DMA

### 9.14.2 Block Diagram

The following figure shows a block diagram of the CIR\_TX.

Figure 9-116 CIR\_TX Block Diagram



### 9.14.3 Functional Description

#### 9.14.3.1 External Signals

The following table describes the external signals of CIR\_TX.

**Table 9-41 CIR\_TX External Signals**

| Signal | Description                   | Type |
|--------|-------------------------------|------|
| CIR-TX | Consumer infrared transmitter | O    |

#### 9.14.3.2 Clock Sources

**Figure 9-117 CIR\_TX Clock System**



#### 9.14.3.3 Function Implementation

The CIR\_TX is used to generate a waveform of arbitrary length, arbitrary shape, and no high-speed requirement, and it can change the data into the high-/low-level sequence of a certain length. Every transmitting data is in bytes, the Bit[7] of a byte means whether the level of a transmitting wave is high or low, the Bit[6:0] is the length of this wave. If the current transmitting frequency-division is 1, 0x88 is a high level of 8 cycles, 0x08 is a low level of 8 cycles. If the current transmitting frequency-division is 4, 0x88 is a high level of 32 cycles, 0x08 is a low level of 32 cycles.

The CIR\_TX has two transmission modes: non-cycle transmission, and cycle transmission.

The non-cycle transmission is to transmit all the data in TX\_FIFO until the FIFO is empty.

The cycle transmission is to transmit all the data in TX\_FIFO, after the transmission completion, wait for a certain time to recover the data in TX\_FIFO and then send it until a stop signal is detected. The data recovery in FIFO is implemented by clearing the read pointer.

#### 9.14.3.4 Timing Diagram

The CIR remote control contains many protocols designed by different manufacturers. Here to NEC protocol as an example, the CIR-TX module uses a variable pulse-width modulation technique to encompass the various formats of infrared encoding for remote-control applications. A message is started by a 9 ms AGC burst, which is used to set the gain of the earlier CIR receivers. This AGC burst is then followed by a 4.5 ms space, which is then followed by the address and command.

Bit definition: the logical “1” takes 2.25 ms to transmit, while a logical “0” is only 1.12 ms.

Figure 9-118 Definitions of Logical “1” and Logical “0”



Timing for a message:

Figure 9-119 CIR Message Timing Diagram



#### 9.14.4 Programming Guidelines

Figure 9-120 CIR Transmitter Process



### 9.14.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| CIR_TX      | 0x02003000   |

| Register Name | Offset | Description                                            |
|---------------|--------|--------------------------------------------------------|
| CIR_TGLR      | 0x0000 | CIR Transmit Global Register                           |
| CIR_TMCR      | 0x0004 | CIR Transmit Modulation Control Register               |
| CIR_TCR       | 0x0008 | CIR Transmit Control Register                          |
| CIR_IDC_H     | 0x000C | CIR Transmit Idle Duration Threshold High Bit Register |
| CIR_IDC_L     | 0x0010 | CIR Transmit Idle Duration Threshold Low Bit Register  |
| CIR_TICR_H    | 0x0014 | CIR Transmit Idle Counter High Bit Register            |
| CIR_TICR_L    | 0x0018 | CIR Transmit Idle Counter Low Bit Register             |
| CIR_TEL       | 0x0020 | CIR TX FIFO Empty Level Register                       |
| CIR_TXINT     | 0x0024 | CIR Transmit Interrupt Control Register                |
| CIR_TAC       | 0x0028 | CIR Transmit FIFO Available Counter Register           |
| CIR_TXSTA     | 0x002C | CIR Transmit Status Register                           |
| CIR_TXT       | 0x0030 | CIR Transmit Threshold Register                        |
| CIR_DMA       | 0x0034 | CIR DMA Control Register                               |
| CIR_TXFIFO    | 0x0080 | CIR Transmit FIFO Data Register                        |

### 9.14.6 Register Description

#### 9.14.6.1 0x0000 CIR Transmitter Global Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CIR_TGLR                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                      |
| 7              | R/W        | 0x0         | IMS<br>Internal Modulation Select<br>0: The transmitting signal is not modulated<br>1: The transmitting signal is modulated internally |

| Offset: 0x0000 |            |             | Register Name: CIR_TGLR                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                     |
| 6:5            | R/W        | 0x0         | <p>DRMC</p> <p>Duty ratio of modulated carrier is high level/low level.</p> <p>00: Low level is equal to high level</p> <p>01: Low level is the double of high level</p> <p>10: Low level is the triple of high level</p> <p>11: Reserved</p>                                                                   |
| 4:3            | /          | /           | /                                                                                                                                                                                                                                                                                                               |
| 2              | R/W        | 0x0         | <p>TPPI</p> <p>Transmit Pulse Polarity Invert</p> <p>0: Not invert transmit pulse</p> <p>1: Invert transmit pulse</p>                                                                                                                                                                                           |
| 1              | R/W        | 0x0         | <p>TR</p> <p>Transmit Reset</p> <p>When this bit is set, the transmitting is reset. The FIFO will be flushed, the TIC filed and the CSS field will be cleared during Transmit Reset. This field will automatically be cleared when the Transmit Reset is finished, and the CIR transmitter will state Idle.</p> |
| 0              | R/W        | 0x0         | <p>TXEN</p> <p>Transmit Block Enable</p> <p>0: Disable the CIR Transmitter</p> <p>1: Enable the CIR Transmitter</p>                                                                                                                                                                                             |

#### 9.14.6.2 0x0004 CIR Transmitter Modulation Control Register (Default Value: 0x0000\_009E)

| Offset: 0x0004 |            |             | Register Name: CIR_TMCR                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:0            | R/W        | 0x9E        | <p>RFMC</p> <p>Reference Frequency of modulated carrier.</p> <p>Reference Frequency of modulated carrier based on a division of a fixed functional clock (FCLK). The range of the modulated carrier is usually 30 kHz to 60 kHz. Most consumer electronics is 38 kHz.</p> <p>The default modulated carrier is 38 kHz when FCLK is 12 MHz.</p> <p><math>RFMC = FCLK / ((N+1) * (DRMC + 2))</math>.</p> |

### 9.14.6.3 0x0008 CIR Transmitter Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CIR_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7              | R/W        | 0x0         | <p>CSS<br/>Cyclical Pulse Start/Stop Control<br/>0: Stop when cleared to '0'. From start to stop, all data in FIFO must be transmitted.<br/>1: Start. Start to transmit when it is set to '1'.</p>                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6:4            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:1            | R/W        | 0x0         | <p>RCS<br/>Reference Clock Select for CIR Transmit<br/>The data in TX_FIFO is used to describe the pulse in Run-Length Code. The basic unit of pulse width is Reference Clock.<br/>000: CIR Transmit reference clock is ir_clk<br/>001: CIR Transmit reference clock is ir_clk/2<br/>010: CIR Transmit reference clock is ir_clk/4<br/>011: CIR Transmit reference clock is ir_clk/8<br/>100: CIR Transmit reference clock is ir_clk/64<br/>101: CIR Transmit reference clock is ir_clk/128<br/>110: CIR Transmit reference clock is ir_clk/256<br/>111: CIR Transmit reference clock is ir_clk/512</p> |
| 0              | R/W        | 0x0         | <p>TTS<br/>Type of the transmission signal<br/>0: The transmitting wave is a single non-cyclical pulse.<br/>1: The transmitting wave is a cyclical short-pulse.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 9.14.6.4 0x000C CIR Transmitter Idle Duration Counter High Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CIR_IDC_H |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:8           | /          | /           | /                        |

| Offset: 0x000C |            |             | Register Name: CIR_IDC_H                                                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | <p>IDC_H</p> <p>Idle Duration Counter Threshold (High 4 bits)</p> <p>Idle Duration = 128*IDC*Ts (IDC = 0~4095)</p> <p>It is used in cyclical transmission mode. When all the data in FIFO is transmitted, the signals can be transmitted after a specific time.</p> |

#### 9.14.6.5 0x0010 CIR Transmitter Idle Duration Counter Low Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: CIR_IDC_L                                                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                  |
| 3:0            | R/W        | 0x0         | <p>IDC_L</p> <p>Idle Duration Counter Threshold (Low 8 bits)</p> <p>Idle Duration = 128*IDC*Ts (IDC = 0~4095)</p> <p>It is used in cyclical transmission mode. When all the data in FIFO is transmitted, the signals can be transmitted after a specific time.</p> |

#### 9.14.6.6 0x0014 CIR Transmitter Idle Counter High Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: CIR_TICR_H                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:0            | R          | 0x0         | <p>TIC_H</p> <p>Transmit Idle Counter_H (High 8 bits)</p> <p>It is used to count the idle duration of CIR transmitter by software.</p> <p>Count in 128*Ts (Sample Duration, 1/Fs) when the transmitter is idle, and it should be reset when the transmitter is active.</p> <p>When this counter reaches the maximum value (0xFFFF), it will stop automatically, and should not be cleared to zero.</p> |

#### 9.14.6.7 0x0018 CIR Transmitter Idle Counter Low Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: CIR_TICR_L                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                               |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                         |
| 7:0            | R          | 0x0         | <p>TIC_L<br/>Transmit Idle Counter_L (Low 8 bits)<br/>It is used to count the idle duration of CIR transmitter by software.<br/>Count in 128*Ts (Sample Duration, 1/Fs) when the transmitter is idle, and it should be reset when the transmitter is active.<br/>When this counter reaches the maximum value (0xFFFF), it will stop automatically, and should not be cleared to zero.</p> |

#### 9.14.6.8 0x0020 CIR Transmitter FIFO Empty Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CIR_TEL                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:8           | /          | /           | /                                                                               |
| 7:0            | R/W        | 0x0         | <p>TEL<br/>TX FIFO empty Level for DRQ and IRQ.<br/>TRIGGER_LEVEL = TEL + 1</p> |

#### 9.14.6.9 0x0024 CIR Transmitter Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CIR_TXINT                                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                        |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                  |
| 2              | R/W        | 0x0         | <p>DRQ_EN<br/>TX FIFO DMA Enable<br/>0: Disable<br/>1: Enable<br/>When it is set to '1', the TX FIFO DRQ is asserted if the number of the transmitting data in the FIFO is less than the RAL. The DRQ is de-asserted when the condition fails.</p> |

| Offset: 0x0024 |            |             | Register Name: CIR_TXINT                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                              |
| 1              | R/W        | 0x0         | <p>TAI_EN<br/>TX FIFO Available Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                        |
| 0              | R/W        | 0x0         | <p>TPEI_EN<br/>Transmit Packet End Interrupt Enable for Cyclical Pulse<br/>0: Disable<br/>1: Enable</p> <p>TUI_EN<br/>Transmitter FIFO Underrun Interrupt Enable for Non-cyclical Pulse<br/>0: Disable<br/>1: Enable</p> |

#### 9.14.6.10 0x0028 CIR Transmitter FIFO Available Counter Register (Default Value: 0x0000\_0080)

| Offset: 0x0028 |            |             | Register Name: CIR_TAC                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                      |
| 7:0            | R          | 0x80        | <p>TAC<br/>TX FIFO Available Space Counter<br/>0x00: No available space in TX FIFO<br/>0x01: 1 byte available space in TX FIFO<br/>0x02: 2 bytes available space in TX FIFO<br/>...<br/>0x80: 128 bytes available space in TX FIFO</p> |

#### 9.14.6.11 0x002C CIR Transmitter Status Register (Default Value: 0x0000\_0002)

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

| Offset: 0x002C |            |             | Register Name: CIR_TXSTA                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3              | R          | 0x0         | <p>STCT<br/>Status of CIR Transmitter<br/>0: Idle<br/>1: Active</p> <p>This bit will automatically set when the controller begins to transmit the data in the FIFO. The “1” will last when the data in the FIFO. It will automatically be cleared to “0” when all data in the FIFO is transmitted.</p> <p>The bit is for debugging.</p> <p>The output Level of Idle state is determined by the level of the last data output.</p> |
| 2              | R          | 0x0         | <p>DRQ<br/>DMA Request Flag</p> <p>When set to ‘1’, the TX FIFO DRQ is asserted if the number of the transmission data in the FIFO is less than the RAL. The DRQ is de-asserted when the condition fails.</p> <p>This bit is for debugging.</p>                                                                                                                                                                                   |
| 1              | R/W        | 0x1         | <p>TAI<br/>TX FIFO Available Interrupt Flag</p> <p>0: TX FIFO not available by its level<br/>1: TX FIFO available by its level</p> <p>Writing 1 clears this bit.</p>                                                                                                                                                                                                                                                              |
| 0              | R/W        | 0x0         | <p>TPE<br/>Transmitter Packet End Flag for Cyclical Pulse</p> <p>0: Transmissions of address, control and data fields not completed<br/>1: Transmissions of address, control and data fields completed</p> <p>TUR<br/>Transmitter FIFO Underrun Flag for Non-cyclical Pulse</p> <p>0: No transmitter FIFO underrun<br/>1: Transmitter FIFO underrun</p> <p>Writing 1 clears this bit.</p>                                         |

**9.14.6.12 0x0030 CIR Transmitter Threshold Register (Default Value: 0x0000\_0000)**

| Offset: 0x0030 |            |             | Register Name: CIR_TXT                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
| 31:8           | /          | /           | /                                                                                                                                                                                              |
| 7:0            | R/W        | 0x0         | NCTT<br>Non-cyclical Pulse Transmit Threshold<br>The controller will trigger transmitting the data in the FIFO when the data byte number has reached the Transmit Threshold set in this field. |

**9.14.6.13 0x0034 CIR Transmitter DMA Control Register (Default Value: 0x0000\_00A5)**

| Offset: 0x0034 |            |             | Register Name: CIR_DMA_CTL                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:8           | /          | /           | /                                                                                       |
| 7:0            | R/W        | 0xA5        | DMA Handshake Configuration<br>0xA5: DMA waiting cycle mode<br>0xEA: DMA handshake mode |

**9.14.6.14 0x0080 CIR Transmitter FIFO Data Register (Default Value: 0x0000\_0000)**

| Offset: 0x0080 |            |             | Register Name: CIR_TXFIFO                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:8           | /          | /           |                                                                                                                                                            |
| 7:0            | W          | 0x0         | TBF<br>Transmit Byte FIFO<br>When the transmission is triggered, the data in the FIFO will be transmitted until the data number is transmitted completely. |

## 9.15 CAN

The CAN (Controller Area Network) module supports the CAN 2.0A/B protocol as defined in the BOSCH CAN bus specification 2.0.CAN is in the CPUX and R-CAN is in the CPUS.

## Contents

|                                     |      |
|-------------------------------------|------|
| 10 Security System.....             | 1329 |
| 10.1 Crypto Engine .....            | 1329 |
| 10.1.1 Overview .....               | 1329 |
| 10.1.2 Block Diagram .....          | 1330 |
| 10.1.3 Functional Description ..... | 1330 |
| 10.1.4 Programming Guidelines.....  | 1350 |
| 10.1.5 Register List.....           | 1353 |
| 10.1.6 Register Description .....   | 1354 |
| 10.2 Security ID .....              | 1358 |

## Figures

|                                                                                             |      |
|---------------------------------------------------------------------------------------------|------|
| Figure 10-1 CE Block Diagram .....                                                          | 1330 |
| Figure 10-2 DES Encryption and Decryption .....                                             | 1331 |
| Figure 10-3 3DES Encryption and Decryption of a 3-key Operation and a 2-key Operation ..... | 1332 |
| Figure 10-4 ECB Mode Encryption and Decryption.....                                         | 1333 |
| Figure 10-5 CBC Mode Encryption and Decryption .....                                        | 1334 |
| Figure 10-6 CTR Mode Encryption and Decryption.....                                         | 1335 |
| Figure 10-7 CFB Mode Encryption and Decryption.....                                         | 1336 |
| Figure 10-8 OFB Mode Encryption and Decryption .....                                        | 1337 |
| Figure 10-9 CTS Mode Encryption and Decryption .....                                        | 1338 |
| Figure 10-10 Structure of Task Descriptor Chaining.....                                     | 1339 |
| Figure 10-11 Word Address of Message .....                                                  | 1346 |
| Figure 10-12 Byte Order.....                                                                | 1346 |
| Figure 10-13 Bit Order .....                                                                | 1346 |
| Figure 10-14 The Storage Method of 32-bit IV .....                                          | 1347 |
| Figure 10-15 The Storage Method of 64-bit IV .....                                          | 1347 |
| Figure 10-16 Task Request Process.....                                                      | 1350 |

# 10 Security System

## 10.1 Crypto Engine

### 10.1.1 Overview

The Crypto Engine(CE) module is one encryption/decryption algorithm accelerator. It supports kinds of symmetric, asymmetric, Hash, and RNG algorithms.

The symmetric algorithm supports data encryption and decryption by following the data encryption standard (DES), 3DES, or advanced encryption standard (AES) algorithms. It can encrypt or decrypt a large amount of data effectively.

The Rivest-Shamir-Adleman (RSA) asymmetric algorithm is used for data encryption/decryption and digital signature verification. It is a public key encryption/decryption algorithm implemented through the modular exponentiation operation.

The Hash algorithm supports data integrity authentication and digital signature. The hash supports MD5, SHA1, SHA224, SHA256, SHA384, SHA512, HMAC-SHA1, and HMAC-SHA256 algorithms.

The RNG algorithm can generate true-random numbers and pseudo-random numbers.

The T113x has two separate CE controllers: one CE is for secure world, the other CE is for non-secure world. The software interface of the CE is simple, only setting interrupt control, task description address, and load tag. The algorithm control information is written in memory by task descriptor, then the CE automatically reads it when executing a request. It supports parallel execution of 4 channels and has an internal DMA controller to transfer data between CE and memory.

The CE has the following features:

- Symmetrical algorithm: AES, DES, 3DES
- Hash algorithm: MD5, SHA1, SHA224, SHA256, SHA384, SHA512, HMAC-SHA1, HMAC-SHA256
- Asymmetrical algorithm: RSA512/1024/2048-bit
- 160-bit hardware PRNG with 175-bit seed
- 256-bit hardware TRNG
- Electronic codebook (ECB), cipher block chaining (CBC), counter (CTR), cipher text stealing (CTS), 128-output feedback (OFB), 1-/8-/64-/128-cipher feedback (CFB) modes for AES algorithm
- ECB, CBC, CTR modes for DES/3DES algorithm
- 128-, 192-, 256-bit key size for AES algorithms
- 16-, 32-, 64-, 128-bit wide size for AES CTR mode

- 16-, 32-, 64-bit wide size for DES/3DES CTR mode
- One or more blocks mode for MD5/SHA1/SHA224/SHA256/SHA384/SHA512
- Internal DMA controller for data transfer with memory
- Supports secure and non-secure interfaces respectively

### 10.1.2 Block Diagram

The following figure shows the block diagram of Crypto Engine.

**Figure 10-1 CE Block Diagram**



### 10.1.3 Functional Description

#### 10.1.3.1 DES Algorithm

Figure 10-2 shows the DES encryption and decryption operation.

**Figure 10-2 DES Encryption and Decryption**

#### 10.1.3.2 3DES Algorithm

The 3DES algorithm supports both 3-key and 2-key operations. A 2-key operation can be regarded as a simplified 3-key operation. To be specific, key 3 is represented by key 1 in a 2-key operation. Figure 10-3 shows the 3DES encryption and decryption operation of a 3-key operation and a 2-key operation.

**Figure 10-3 3DES Encryption and Decryption of a 3-key Operation and a 2-key Operation**

#### 10.1.3.3 ECB Mode

The ECB mode is a confidentiality mode that features, for a given key, the assignment of a fixed ciphertext block to each plaintext block, analogous to the assignment of code words in a codebook.

In ECB mode, encryption and decryption algorithms are directly applied to the block data. The operation of each block is independent, so the plaintext encryption and ciphertext decryption can be performed concurrently.

**Figure 10-4 ECB Mode Encryption and Decryption**

#### 10.1.3.4 CBC Mode

The CBC mode is a confidentiality mode whose encryption process features the combining of the plaintext blocks with the previous ciphertext blocks. The CBC mode requires an initialization vector (IV) to combine with the first plaintext block. The encryption process of each plaintext block is related to the block processing result of the previous ciphertext blocks, so encryption operations cannot be concurrently performed in CBC mode. The decryption operation is independent of output plain text of the previous block, so decryption operations can be performed concurrently.

**Figure 10-5 CBC Mode Encryption and Decryption**

#### 10.1.3.5 CTR Mode

The CTR mode is a confidentiality mode that features the application of the forward cipher to a set of input blocks, called counters, to produce a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. All of the counters must be distinct.

Figure 10-6 CTR Mode Encryption and Decryption



#### 10.1.3.6 CFB Mode

The CFB mode is a confidentiality mode that features the feedback of successive ciphertext segments into the input blocks of the forward cipher to generate output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The CFB mode requires an IV as the initial input block, and the forward cipher operation is applied to the IV to produce the first output block. The first ciphertext segment is produced by exclusive-ORing the first plaintext segment with the s most significant bits of the first output block. The value of s is 1 bit, 8 bits, 64 bits, or 128 bits.

The following figure shows the s-bit CFB mode of the AES algorithms.

Figure 10-7 CFB Mode Encryption and Decryption



#### 10.1.3.7 OFB Mode

The OFB mode is a confidentiality mode that features the iteration of the forward cipher on an IV to generate a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. If a same key is used, different IVs must be used to ensure operation security.

Figure 10-8 OFB Mode Encryption and Decryption



#### 10.1.3.8 CTS Mode

The CTS mode is a confidentiality mode that accepts any plaintext input whose bit length is greater than or equal to the block size but not necessarily a multiple of the block size. Below are the diagrams for CTS encryption and decryption.

Figure 10-9 CTS Mode Encryption and Decryption



### 10.1.3.9 HASH Algorithm

The hash algorithms support MD5, SHA1, SHA224, SHA256, SHA384, SHA512, HMAC-SHA1, and HMAC-SHA256. All algorithms are iterative, one-way hash functions that can process a message to produce a condensed representation called a *message digest*. When a message is received, the *message digest* can be used to verify whether the data has changed, that is, to verify its integrity.

The hash algorithm of the CE supports block-aligned total length of the input data (padded by software), that is, a multiple of 64 bytes. The message length after padding by software is used as the configured data length for the hash algorithm.

### 10.1.3.10 RSA Algorithm

The RSA is a public key encryption/decryption algorithm implemented through the modular exponentiation operation.

The ciphertext is obtained as follows:  $C = M^E \bmod N$ . The plaintext is obtained as follows:  $M = C^D \bmod N$ .

$M$  indicates the plaintext,  $C$  indicates the ciphertext,  $(N, E)$  indicates the public key, and  $(N, D)$  indicates the private key.

#### 10.1.3.11 Task Descriptor

The software makes request through task descriptor, including algorithm type, algorithm mode, key address, source/destination address and size, and so on. The structure of the task descriptor is as follows.

**Figure 10-10 Structure of Task Descriptor Chaining**



The bit definitions of the task descriptor are as follows.

##### Task ID

| Bit  | Read/Write | Default/Hex | Description |
|------|------------|-------------|-------------|
| 31:4 | /          | /           | /           |

| Bit | Read/Write | Default/Hex | Description                                                                                                         |
|-----|------------|-------------|---------------------------------------------------------------------------------------------------------------------|
| 3:0 | R/W        | 0x0         | <p>CHN</p> <p>Task channel ID</p> <p>Indicates which channel the task is running on.</p> <p>It supports 0 to 3.</p> |

**Common Control**

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0x0         | <p>Interrupt enable (IE) for the current task</p> <p>0: disable interrupt</p> <p>1: enable interrupt</p> <p>Represents whether an interrupt signal is generated when the task chain ends at the end of this task.</p> <p>When the last task in a task chain ends, the operation of the task chain will end normally; if a task fails in the middle, the task chain will be aborted abnormally. And it is determined whether to generate an interrupt signal according to the IE configuration of the current task when the current task ends or aborts. Therefore, if you want to use interrupts, it is recommended that not only the IE of the last task of each task chain is configured to 1 to generate the end interrupt of the task chain, but also the IEs of other tasks in this task chain are also configured to 1. The purpose is to generate an interrupt signal once an abnormal error occurs in these tasks and the interrupt is aborted.</p> |
| 30:17 | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16    | R/W        | 0x0         | <p>IV mode</p> <p>IV mode for SHA1/SHA224/SHA256/SHA384/SHA512/MD5 or constants</p> <p>0: use initial constants defined in FIPS-180</p> <p>1: use input iv</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15    | R/W        | 0x0         | <p>Last HMAC plaintext</p> <p>0: not the last HMAC plaintext package</p> <p>1: the last HMAC plaintext package</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 14:9  | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Bit | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                           |
|-----|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | R/W        | 0x0         | OP DIR<br>Algorithm Operation Direction<br>0: Encryption<br>1: Decryption<br>Configure according to the requirements of encryption or decryption.                                                                                                                     |
| 7   | /          | /           | /                                                                                                                                                                                                                                                                     |
| 6:0 | R/W        | 0x0         | Algorithm Type<br>0x0: AES<br>0x1: DES<br>0x2: Triple DES (3DES)<br>0x10: MD5<br>0x11: SHA-1<br>0x12: SHA-224<br>0x13: SHA-256<br>0x14: SHA-384<br>0x15: SHA-512<br>0x16: HMAC-SHA1<br>0x17: HMAC-SHA256<br>0x20: RSA<br>0x30: TRNG<br>0x31: PRNG<br>Others: reserved |

## Symmetric Control

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                |
|-------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | /          | /           | /                                                                                                                                                                                                                          |
| 23:20 | R/W        | 0x0         | KEY_SELECT<br>key select for AES<br>0000: Select input CE_KEYx (Normal Mode)<br>0001: Select {SSK}<br>0010: Select {HUK}<br>0011: Select {RSSK}<br>0100-0111: Reserved<br>1000-1111: Select internal Key n (n from 0 to 7) |

| <b>Bit</b> | <b>Read/Write</b> | <b>Default/Hex</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:18      | R/W               | 0x0                | CFB_WIDTH<br>AES-CFB width<br>00: CFB1<br>01: CFB8<br>10: CFB64<br>11: CFB128                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17         | R/W               | 0x0                | PRNG_LD<br>Load new 15 bits key into linear feedback shift register (LFSR) for PRNG.<br>When the algorithm type is PRNG, it is necessary to post-process the random number output by PRNG through the linear shift operation to generate the operand.<br>When the PRNG_LD is configured to 1, use iv_addr[14:0] as the input number for linear shift operation, and do XOR operation between the data and the random number output by PRNG to generate the post-processing result of further operation. |
| 16         | R/W               | 0x0                | CTS_LPKG<br>AES CTS last package flag<br>When set to '1', it means this is the last package for AES-CTS mode (the size of the last package is larger than 128 bits).                                                                                                                                                                                                                                                                                                                                    |
| 15:12      | /                 | /                  | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 11:8       | R/W               | 0x0                | ALGORITHM_MODE<br>CE algorithm mode<br>0000: Electronic Code Book (ECB) mode<br>0001: Cipher Block Chaining (CBC) mode<br>0010: Counter (CTR) mode<br>0011: Cipher Text Stealing (CTS) mode<br>0100: Output Feedback (OFB) mode<br>0101: Cipher Feedback (CFB) mode<br>Other: reserved                                                                                                                                                                                                                  |
| 7:4        | /                 | /                  | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3:2        | R/W               | 0x0                | CTR WIDTH<br>Counter width for CTR mode<br>00: 16-bit Counter<br>01: 32-bit Counter<br>10: 64-bit Counter<br>11: 128-bit Counter                                                                                                                                                                                                                                                                                                                                                                        |

| Bit | Read/Write | Default/Hex | Description                                                               |
|-----|------------|-------------|---------------------------------------------------------------------------|
| 1:0 | R/W        | 0x0         | AES KEY SIZE<br>00: 128-bit<br>01: 192-bit<br>10: 256-bit<br>11: Reserved |

**Asymmetric Control**

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                               |
|-------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | /          | /           | /                                                                                                                                                                         |
| 30:28 | R/W        | 0x0         | RSA Pubic Modulus Width<br>000: 512-bit<br>001: 1024-bit<br>010: 2048-bit<br>Other: reserved                                                                              |
| 27:19 | /          | /           | /                                                                                                                                                                         |
| 18:16 | R/W        | 0x0         | RSA MODE<br>RSA algorithm mode.<br>For modular computation:<br>000: modular exponent(RSA)<br>001: modular div<br>010: modular mul<br>011: modular inv<br>others: reserved |
| 15:0  | /          | /           | /                                                                                                                                                                         |

**Key Descriptor**

| Bit  | Read/Write | Default/Hex | Description                                                |
|------|------------|-------------|------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Key Address<br>The address of KEY that needs to be stored. |

**IV Descriptor**

| Bit  | Read/Write | Default/Hex | Description                                              |
|------|------------|-------------|----------------------------------------------------------|
| 31:0 | R/W        | 0x0         | IV Address<br>The address of IV that needs to be stored. |

**Counter Descriptor**

| Bit  | Read/Write | Default/Hex | Description                                                                        |
|------|------------|-------------|------------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | CTR Data Output Address<br>The address of CTR data output that needs to be stored. |

**Data Length**

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | <p>Data Length<br/>Configure the data length of the corresponding segment. The data length size needs to be consistent with dst_data_length (destination data length 0 +... + destination data length 7).</p> <p>The data length field in the task descriptor has different meanings for different algorithms.</p> <p>For AES-CTS, the data length field indicates byte numbers of source data, for others indicate word numbers of source data.</p> <p>For PRNG, the data length should be 5 words aligned.</p> <p>For TRNG, it should be 8 words aligned.</p> |

**Source Address 0~7**

| Bit  | Read/Write | Default/Hex | Description                                                                    |
|------|------------|-------------|--------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Source Data Address<br>The address of the source data that needs to be stored. |

**Source Data Length 0~7**

| Bit  | Read/Write | Default/Hex | Description                                                        |
|------|------------|-------------|--------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Source Data Length<br>The length of the source data.<br>Unit: byte |

**Destination Address 0~7**

| Bit  | Read/Write | Default/Hex | Description                                                                              |
|------|------------|-------------|------------------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Destination Data Address<br>The address of the destination data that needs to be stored. |

**Destination Data Length 0~7**

| Bit  | Read/Write | Default/Hex | Description                                                                  |
|------|------------|-------------|------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Destination Data Length<br>The length of the destination data.<br>Unit: byte |

**Next Descriptor Address**

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
|------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R/W        | 0x0         | Next Task Address<br>The address where the descriptor of the next task in a task-chain is saved. If there is the only task or the last task of a task-chain, the next task address must be 32'h0. |

**10.1.3.12 Storing Message**

In the application, a message may not be stored contiguously in the memory, but divided into multiple segments. Or a piece of continuously stored messages can be artificially split into multiple pieces as needs.

Then each segment corresponds to a set of the source address and source length in the descriptor. Multiple segments correspond to groups 0-7 source address/source length in sequence.

Each task supports up to 8 message segments, and the data volume of each message segment supports up to 4 GWord (AES-CTS is 1 GByte). The total amount of all segments in a task (that is a package) supports up to 4 GWord (AES-CTS is 1 GByte). If a message is divided into multiple packages, all others are required to be whole words; when the last package of AES-CTS is less than one word, 0 needs to be padded, and those less than one word are counted as one word. The following figure shows the address order structure.

**Figure 10-11 Word Address of Message**



Byte order: low byte first, high byte last. When the data is less than one word, the low byte is filled first. The following figure shows the byte order structure (blue means it is filled by the message).

**Figure 10-12 Byte Order**



Bit order: high bit first, low bit last. When the data is less than one Byte, the high bit is filled first. The following figure shows the bit order structure.

**Figure 10-13 Bit Order**



#### 10.1.3.13 Storing Key

The length of KEY must be an integer multiple of word, refer to section 10.1.3.15 “[Algorithm Length Properties](#)”.

### 10.1.3.14 Storing IV

For different algorithms, the length of IV is different. But they are integer multiples of word. To keep the byte order of IV and HASH digest output consistent, the byte order of IV is different from that of the message. For the multi-packet operation, the first address of the digest output result of the previous HASH can be directly configured to the first address of the next IV, and the software does not need to do any processing on the digest.

The following figure shows the storage method of 32-bit IV value.

**Figure 10-14 The Storage Method of 32-bit IV**



The following figure shows the storage method of 64-bit IV value.

**Figure 10-15 The Storage Method of 64-bit IV**



### 10.1.3.15 Algorithm Length Properties

The algorithm length has different requirements for different algorithms.

**Table 10-1 Symmetric Algorithm Configuration Properties**

| Algorithm        | Length Setting |                  |                                                       |        | Alignment    | Software Padding |
|------------------|----------------|------------------|-------------------------------------------------------|--------|--------------|------------------|
|                  | Source Size    | Destination Size | KEY                                                   | IV     |              |                  |
| AES (except CTS) | < 4 GWord      | < 4 GWord        | AES-128: 4 Word<br>AES-192: 6 Word<br>AES 256: 8 Word | 4 Word | Word-aligned | need             |
| AES-CTS          | < 1 GByte      | < 1 GByte        | AES-128: 4 word<br>AES-192: 6 word<br>AES 256: 8 word | 4 Word | Word-aligned | need             |
| DES              | < 4 GWord      | < 4 GWord        | 2 Word                                                | 2 Word | Word-aligned | need             |
| TDES             | < 4 GWord      | < 4 GWord        | 6 Word                                                | 2 Word | Word-aligned | need             |

**Table 10-2 Hash Algorithm Configuration Properties**

| Algorithm   | Length Setting |                  |            |         | Alignment    | Software Padding |
|-------------|----------------|------------------|------------|---------|--------------|------------------|
|             | Source Size    | Destination Size | KEY        | IV      |              |                  |
| MD5         | < 4 GWord      | 4 Word           | Fixed to 0 | 4 Word  | Word-aligned | need             |
| SHA-1       | < 4 GWord      | 5 Word           | Fixed to 0 | 5 Word  | Word-aligned | need             |
| SHA-224     | < 4 GWord      | 8 Word           | Fixed to 0 | 8 Word  | Word-aligned | need             |
| SHA-256     | < 4 GWord      | 8 Word           | Fixed to 0 | 8 Word  | Word-aligned | need             |
| SHA-384     | < 4 GWord      | 16 Word          | Fixed to 0 | 16 Word | Word-aligned | need             |
| SHA-512     | < 4 GWord      | 16 Word          | Fixed to 0 | 16 Word | Word-aligned | need             |
| HMAC-SHA1   | < 4 GWord      | 5 Word           | 16 Word    | 5 Word  | Word-aligned | need             |
| HMAC-SHA256 | < 4 GWord      | 8 Word           | 16 Word    | 8 Word  | Word-aligned | need             |

**Table 10-3 RNG Configuration Properties**

| Algorithm | Length Setting |                  |            |        | Alignment    | Software Padding |
|-----------|----------------|------------------|------------|--------|--------------|------------------|
|           | Source Size    | Destination Size | KEY        | IV     |              |                  |
| TRNG      | < 4 GWord      | < 4 GWord        | Fixed to 0 | 4 Word | Word-aligned | need             |
| PRNG      | < 4 GWord      | < 4 GWord        | 6 Word     | 4 Word | Word-aligned | need             |

**Table 10-4 Asymmetric Algorithm Configuration Properties**

| Algorithm | Length Setting |                  |         |            | Alignment    | Software Padding |
|-----------|----------------|------------------|---------|------------|--------------|------------------|
|           | Source Size    | Destination Size | KEY     | IV         |              |                  |
| RSA512    | 16 Word        | 16 Word          | 16 Word | Not use IV | Word-aligned | need             |
| RSA1024   | 32 Word        | 32 Word          | 32 Word | Not use IV | Word-aligned | need             |
| RSA2048   | 64 Word        | 64 Word          | 64 Word | Not use IV | Word-aligned | need             |

#### 10.1.3.16 Security Operation

When the CPU issues request to the CE module, the CE module will save the secure mode of CPU. When executing this request, this state bit works as a access flag for the inner and system resources. For access to SID module through the AHB bus, only the secure mode can succeed, or else these keys will be read to 0 or cannot write. When issuing MBUS read and write requests, the CE will use send this secure mode bit to BUS, so secure requests can access secure and non-secure space, but non-secure requests only can access non-secure space.

#### 10.1.3.17 Error Detection

The CE module includes error detection for task configuration, data computing error, and authentication invalid. When the algorithm type in task descriptor is read into the CE module, the CE will check whether this type is supported through checking algorithm type field in common control. If the type value is out of scope, the CE will issue interrupt signal and set error state. Each type has certain input and output data size. After getting a task descriptor, the input size and output size configuration will be checked to avoid size error. If the size configuration is wrong, the CE will issue interrupt signal and set error state.

### 10.1.3.18 Clock Requirement

| Clock Name | Description   | Requirement      |
|------------|---------------|------------------|
| hclk       | AHB bus clock | 24 MHz – 200 MHz |
| mclk       | MBUS clock    | 24 MHz – 400 MHz |
| ce_clk     | CE work clock | 24 MHz – 400 MHz |

### 10.1.4 Programming Guidelines

#### 10.1.4.1 Symmetrical/Asymmetrical/Hash/RNG Algorithm Operation Process

The following figure shows the process of an algorithm operation.

Figure 10-16 Task Request Process



**Step 1** The software should configure a task descriptor in memory, including the related fields in the descriptor. The channel id corresponds to one channel in CE. According to algorithm type, the software should set the fields in common control, symmetric control, asymmetric control, then provide key/iv/ctr address and the data length of this task. The source and destination address and size are set based on the upper application. If there is another task concatenating after this task, then set its descriptor address at the next descriptor field. For more details for task descriptor, see section 10.1.4.2, section 10.1.4.3 and section 10.1.4.4.

- Step 2** The software should set registers. Configure the first address of the task descriptor structure to [CE Task Descriptor Address Register](#). Configure the source/destination address to [CE Current Source Address Register/CE Current Destination Address Register](#).
- Step 3** Enable the end interrupt of the corresponding task channel by setting [CE Interrupt Control Register](#).
- Step 4** The software reads [CE Task Load Register](#) to ensure that the bit0 is 0. If the bit0 is not read out to be 0, wait until it is 0, then configure the bit0 to be 1 to start task.
- Step 5** Wait for interrupt status by reading [CE Interrupt Status Register](#).
- Step 6** Read the result from the destination address.
- Step 7** Clear the interrupt.

#### 10.1.4.2 Configuring Task Descriptor of AES

- **Common control:** Configure [Common Control](#)[6:0] to 0x0 to select AES algorithm type.
- **Symmetric control:** According to the corresponding algorithm requirements, configure [Symmetric Control](#) to select the key size, CTR width, CTS last package flag, CFB width, and AES algorithm mode, and so on.
- **Asymmetric control:** The symmetric algorithm does not need to be configured for this field.
- **Key descriptor:** Because the storage of the key requires word alignment, ensure that this descriptor is the first address of the KEY (word address).
- **IV descriptor:** In the task that requires the IV value, configure the first address of the storage space where the IV is stored here. Because the storage of the IV requires word alignment, ensure that this descriptor is the first address of the IV (word address).
- **Data length:** Configure the data length of the corresponding segment. The data length size needs to be consistent with dst\_data\_length (destination data length 0 +... + destination data length 7). When the algorithm is CTS mode, the higher 30-bit of the data length is the word numbers of data volume; when the data\_length[1:0] is 0, the data length is the higher 30-bit, otherwise it is increased by 1. For AES CTS, the data length indicates the byte numbers of the source data; for other algorithms, it indicates the word numbers.
- **Source address:** The first address of source data segments. Because the storage of the source data requires word alignment, ensure that this descriptor is the first address (word address).
- **Source data length:** The data volume of source data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Destination address:** The first address of destination data segments. Because the storage of the destination data requires word alignment, ensure that this descriptor is the first address (word address).

- **Destination data length:** The data volume of destination data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Next descriptor:** The first address of the next task descriptor. Because the storage of the descriptor requires word alignment, ensure that this descriptor is the first address (word address).
- **Reserved:** Configure to 0x0.

#### 10.1.4.3 Configuring Task Descriptor of HASH

- **Common control**
  - **Algorithm type:** Configure [Common Control](#)[6:0] to select SHA or HMAC algorithm type.
  - **Last HMAC plaintext:** If the algorithm type is HMAC, and the task is the last package of the message or if the message has only one package, then [Common Control](#)[15] needs to set to 1.
  - **IV mode:** The [Common Control](#)[16] (IV MODE) bit is only set to 1 in the following two scenarios, except that the bit must be configured to 0. (1). When the message is split into multiple packages, the [Common Control](#)[16] bit of other packages needs to be set to 1, except that the bit of the first package needs to be cleared to 0. (2). In special applications, if you need to customize the IV value to form the initial value of a certain HASH algorithm, you need to set the [Common Control](#)[16] bit of the first (or only one) package to 1, and the first address of the storage space where the customized IV value is stored in IV address.
- **Key descriptor:** Because the storage of the key requires word alignment, ensure that this descriptor is the first address of the KEY (word address).
- **IV descriptor:** In the task that requires the IV value, configure the first address of the storage space where the IV is stored here. Because the storage of the IV requires word alignment, ensure that this descriptor is the first address of the IV (word address).
- **Data length:** Configure the data length of the corresponding segment. The data length size needs to be consistent with dst\_data\_length (destination data length 0 +... + destination data length 7).
- **Source address:** The first address of source data segments. Because the storage of the source data requires word alignment, ensure that this descriptor is the first address (word address).
- **Source data length:** The data volume of source data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Destination address:** The first address of destination data segments. Because the storage of the destination data requires word alignment, ensure that this descriptor is the first address (word address).

- **Destination data length:** The data volume of destination data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Next descriptor:** The first address of the next task descriptor. Because the storage of the descriptor requires word alignment, ensure that this descriptor is the first address (word address).
- **Reserved:** Configure to 0x0.

#### 10.1.4.4 Configuring Task Descriptor of RSA

- **Common control:** Configure [Common Control](#)[6:0] to 0x20 to select RSA algorithm type.
- **Asymmetric control:** Configure [Asymmetric Control](#)[30:28] to select the RSA width.
- **Key descriptor:** Because the storage of the key requires word alignment, ensure that this descriptor is the first address of the KEY (word address).
- **Data length:** Configure the data length of the corresponding segment. The data length size needs to be consistent with dst\_data\_length (destination data length 0 +...+ destination data length 7).
- **Source address:** The first address of source data segments. Because the storage of the source data requires word alignment, ensure that this descriptor is the first address (word address).
- **Source data length:** The data volume of source data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Destination address:** The first address of destination data segments. Because the storage of the destination data requires word alignment, ensure that this descriptor is the first address (word address).
- **Destination data length:** The data volume of destination data segments. The unit is word, and those less than one word are counted as one word. Note that only the last word of the entire message is allowed to be non-integer words, and the others must be integer words.
- **Next descriptor:** The first address of the next task descriptor. Because the storage of the descriptor requires word alignment, ensure that this descriptor is the first address (word address).
- **Reserved:** Configure to 0x0.

#### 10.1.5 Register List

| Module Name             | Base Address |
|-------------------------|--------------|
| CE_NS (Non-Security CE) | 0x03040000   |

| Module Name        | Base Address |
|--------------------|--------------|
| CE_S (Security CE) | 0x03040800   |

| Register Name | Offset | Description                     |
|---------------|--------|---------------------------------|
| CE_TDA        | 0x0000 | Task Descriptor Address         |
| CE_ICR        | 0x0008 | Interrupt Control Register      |
| CE_ISR        | 0x000C | Interrupt Status Register       |
| CE_TLR        | 0x0010 | Task Load Register              |
| CE TSRMLS     | 0x0014 | Task Status Register            |
| CE_ESR        | 0x0018 | Error Status Register           |
| CE_CSA        | 0x0024 | DMA Current Source Address      |
| CE_CDA        | 0x0028 | DMA Current Destination Address |
| CE_TPR        | 0x002C | Throughput Register             |

### 10.1.6 Register Description

#### 10.1.6.1 0x0000 CE Task Descriptor Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CE_TDA                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                            |
| 31:0           | R/W        | 0x0         | Task Descriptor Address<br>Configure as the first address of the descriptor structure. |

#### 10.1.6.2 0x0008 CE Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CE_ICR                                       |
|----------------|------------|-------------|-------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                 |
| 31:4           | /          | /           | /                                                           |
| 3:0            | R/W        | 0x0         | Task Channel3–0 Interrupt Enable<br>0: Disable<br>1: Enable |

### 10.1.6.3 0x000C CE Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: CE_ISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:4           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3:0            | R/W1C      | 0x0         | <p>Task Channel3–0 End Pending<br/>0: Not finished<br/>1: Finished<br/>It indicates whether task is completed.</p> <p>Write the corresponding channel bit of the register to clear the end flag.</p> <p>When the last task in the task chain ends, the operation of the task chain will end normally. If the task fails in the middle, the task chain will be aborted. The CE_ISR register will be automatically updated when it ends normally or aborts abnormally. And it is determined whether to generate an interrupt signal according to the IE configuration (bit31) of <a href="#">Common Control</a> when the current task ends or aborts.</p> <p>If using interrupt, after receiving the interrupt, read the corresponding channel bit of CE_ISR to judge whether it ends successfully or stops failure.</p> <p>If not using interrupt, the CE_ISR status register can be continuously queried for the channel bit until the successful end flag is set or the failure stop flag is set. Write the corresponding channel bit of the register to clear the end flag.</p> <p>If it fails to stop, you can read the error code on the channel corresponding to the <a href="#">CE_ESR</a> register.</p> |

### 10.1.6.4 0x0010 CE Task Load Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: CE_TLR                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:1           | /          | /           | /                                                                                                      |
| 0              | R/W        | 0x0         | <p>Task Load</p> <p>When set, the CE can load the descriptor of task if the task FIFO is not full.</p> |

#### 10.1.6.5 0x0014 CE Task Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: CE_TSR                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:2           | /          | /           | /                                                                                                          |
| 1:0            | R          | 0x0         | Running Channel Number<br>00: Task channel0<br>01: Task channel1<br>10: Task channel2<br>11: Task channel3 |

#### 10.1.6.6 0x0018 CE Error Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: CE_ESR                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                |
| 31:16          | /          | /           | /                                                                                                                                          |
| 15:12          | R/W1C      | 0x0         | Task Channel3 Error Type<br>xxx1: Algorithm not support<br>xx1x: Data length error<br>x1xx: keysram access error for AES<br>1xxx: Reserved |
| 11:8           | R/W1C      | 0x0         | Task Channel2 Error Type<br>xxx1: Algorithm not support<br>xx1x: Data length error<br>x1xx: keysram access error for AES<br>1xxx: Reserved |
| 7:4            | R/W1C      | 0x0         | Task Channel1 Error Type<br>xxx1: Algorithm not support<br>xx1x: Data length error<br>x1xx: keysram access error for AES<br>1xxx: Reserved |
| 3:0            | R/W1C      | 0x0         | Task Channel0 Error Type<br>xxx1: Algorithm not support<br>xx1x: Data length error<br>x1xx: keysram access error for AES<br>1xxx: Reserved |

#### 10.1.6.7 0x0024 CE Current Source Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CE_CSA                  |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
| 31:0           | R          | 0x0         | CUR_SRC_ADDR<br>Current source address |

#### 10.1.6.8 0x0028 CE Current Destination Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CE_CDA                       |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:0           | R          | 0x0         | CUR_DST_ADDR<br>Current destination address |

#### 10.1.6.9 0x002C CE Throughput Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: CE_TPR                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:0           | R/WC       | 0x0         | TP_NUM<br>It indicates the throughput writing to this register at last time.<br>Writing to this register will clear it to 0. |

## 10.2 Security ID

The Security ID (SID) is used to program and read keys which include chip ID, thermal sensor, HASH code, and so on.

The SID module has the following features:

- 2 Kbits electrical fuse (eFuse)
- Backup eFuse information by using SID\_SRAM
- A fuse only can program one time
- Burning the key to the SID
- Reading the key use status in the SID
- Loading the key to the CE



### CAUTION

Before performing the burning operation, ensure that the power supply of the eFuse power pin is stable. After the burning operation is completed, cancel the power supply of the eFuse power pin.

## Appendix: Glossary

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

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

| Term     | Meaning                                   |
|----------|-------------------------------------------|
| FEL      | Fireware Exchange Launch                  |
| FIFO     | First In First Out                        |
| <b>G</b> |                                           |
| GPIO     | General Purpose Input Output              |
| <b>I</b> |                                           |
| I2C      | Inter Integrated Circuit                  |
| I2S      | Inter IC Sound                            |
| ISP      | Image Signal Processor                    |
| <b>J</b> |                                           |
| JEDEC    | Joint Electron Device Engineering Council |
| JPEG     | Joint Photographic Experts Group          |
| JTAG     | Joint Test Action Group                   |
| <b>L</b> |                                           |
| LCD      | Liquid-Crystal Display                    |
| LFBGA    | Low Profile Fine Pitch Ball Grid Array    |
| LSB      | Least Significant Bit                     |
| LVDS     | Low Voltage Differential Signaling        |
| <b>M</b> |                                           |
| MAC      | Media Access Control                      |
| MIC      | Microphone                                |
| MIPI     | Mobile Industry Processor Interface       |
| MLC      | Multi-Level Cell                          |
| MMC      | Multimedia Card                           |
| MPEG     | Motion Pictures Expert Group              |
| MSB      | Most Significant Bit                      |
| <b>N</b> |                                           |
| N/A      | Not Application                           |
| NMI      | Non Maskable Interrupt                    |
| NTSC     | National Television Standards Committee   |
| NVM      | Non Volatile Storage Medium               |
| <b>O</b> |                                           |
| OHCI     | Open Host Controller Interface            |
| OTP      | One Time Programmable                     |
| OWA      | One Wire Audio                            |
| <b>P</b> |                                           |
| PAL      | Phase Alternating Line                    |
| PCM      | Pulse Code Modulation                     |
| PHY      | Physical Layer Controller                 |
| PID      | Packet Identifier                         |
| PLL      | Phase-Locked Loop                         |
| POR      | Power-On Reset                            |
| PRCM     | Power Reset Clock Management              |
| PWM      | Pulse Width Modulation                    |

| Term                        | Meaning                                     |
|-----------------------------|---------------------------------------------|
| <b>R</b>                    |                                             |
| R                           | Read only/non-Write                         |
| RGB                         | Read Green Blue                             |
| RGMII                       | Reduced Gigabit Media Independent Interface |
| RMII                        | Reduced Media Independent Interface         |
| ROM                         | Read Only Memory                            |
| RSA                         | Rivest-Shamir-Adleman                       |
| RTC                         | Real Time Clock                             |
| <b>S</b>                    |                                             |
| SAR                         | Successive Approximation Register           |
| SD                          | Secure Digital                              |
| SDIO                        | Secure Digital Input Output                 |
| SDK                         | Software Development Kit                    |
| SDRAM                       | Synchronous Dynamic Random Access Memory    |
| SDXC                        | Secure Digital Extended Capacity            |
| SLC                         | Single-Level Cell                           |
| SoC                         | System on Chip                              |
| SPI                         | Serial Peripheral Interface                 |
| SRAM                        | Static Random Access Memory                 |
| <b>T</b>                    |                                             |
| TDES                        | Triple Data Encryption Standard             |
| <td>Two Wire Interface</td> | Two Wire Interface                          |
| <b>U</b>                    |                                             |
| UART                        | Universal Asynchronous Receiver Transmitter |
| UDF                         | Undefined                                   |
| USB DRD                     | Universal Serial Bus Dual Role Device       |
| UTMI                        | USB2.0 Transceiver Macrocell Interface      |



Confidential

**Copyright©2023 Allwinner Technology Co.,Ltd. All Rights Reserved.**

This documentation is the original work and copyrighted property of Allwinner Technology Co.,Ltd ("Allwinner"). No part of this document may be reproduced, modify, publish or transmitted in any form or by any means without prior written consent of Allwinner.

**Trademarks and Permissions**

Allwinner and the Allwinner logo (incomplete enumeration) are trademarks of Allwinner Technology Co.,Ltd. All other trademarks, trade names, product or service names mentioned in this document are the property of their respective owners.

**Important Notice and Disclaimer**

The purchased products, services and features are stipulated by the contract made between Allwinner Technology Co.,Ltd ("Allwinner") 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. Please read the terms and conditions of the contract and relevant instructions carefully before using, and follow the instructions in this documentation strictly. Allwinner assumes no responsibility for the consequences of improper use (including but not limited to overvoltage, overclock, or excessive temperature).

The information in this document is provided just as a reference or typical applications, and is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents. Allwinner is not responsible for any damage (including but not limited to indirect, incidental or special loss) or any infringement of third party rights arising from the use of this document. All statements, information, and recommendations in this document do not constitute a warranty or commitment of any kind, express or implied.

No license is granted by Allwinner herein express or implied or otherwise to any patent or intellectual property of Allwinner. Third party licences may be required to implement the solution/product. Customers shall be solely responsible to obtain all appropriately required third party licences. Allwinner shall not be liable for any licence fee or royalty due in respect of any required third party licence. Allwinner shall have no warranty, indemnity or other obligations with respect to third party licences.