

# A10s User Manual

**V1.4**

**2015.04.22**

## Revision History

| Version | Date       | Author | Description                                             |
|---------|------------|--------|---------------------------------------------------------|
| V1.00   | 2011.11.30 |        | Initial version                                         |
| V1.10   | 2011.12.30 |        | GPIO E[2:0] and GPIO G[2:0] are changed for INPUT only. |
| V1.11   | 2011.12.31 |        | Revise some register description of Secure System       |
| V1.20   | 2012.10.25 |        | Modify SDRAM/NAND module description                    |
| V1.30   | 2012.12.20 |        | Modify Digital Audio Interface description              |
| V1.40   | 2015.04.22 |        | Add Programming guide of security system                |

# Technical Items

| <b>NO.</b> | <b>Abbreviation</b> | <b>Full Name</b>                            | <b>Description</b>                                                                                                                                                                     |
|------------|---------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1          | ARM Cortex™-A8      | ARM Cortex™-A8                              | A processor core designed by ARM Holdings implementing the ARM v7 instruction set architecture                                                                                         |
| 2          | Mali-400            | Mali-400                                    | A 2D/3D graphic processor unit designed by ARM Holdings                                                                                                                                |
| 3          | SDRAM               | Synchronous Dynamic Random Access Memory    | Dynamic random access memory (DRAM) that is synchronized with the system bus                                                                                                           |
| 4          | PWM                 | Pulse Width Modulator                       | A commonly used technique for controlling power to inertial electrical devices, made practical by modern electronic power switches                                                     |
| 5          | SPI                 | Serial Peripheral Interface                 | A synchronous serial data link standard named by Motorola that operates in full duplex mode. Devices communicate in master/slave mode where the master device initiates the data frame |
| 6          | UART                | Universal Asynchronous Receiver/Transmitter | used for serial communication with a peripheral, modem (data carrier equipment, DCE) or data set                                                                                       |
| 7          | DMA                 | Direct Memory Access                        | A feature of modern computers that allow certain hardware subsystems within the computer to access system memory independently of the CPU                                              |
| 8          | I2S                 | IIS                                         | An electrical serial bus interface standard used for connecting digital audio devices together                                                                                         |
| 9          | PCM                 | Pulse Code Modulation                       | Method used to digitally represent sampled analog signals                                                                                                                              |
| 10         | PWM                 | Pulse Width Modulation                      | A commonly used technique for controlling power to inertial electrical devices, made practical by modern electronic power switches                                                     |
| 11         | Audio Codec         | Audio Codec                                 | A computer program implementing an algorithm that compresses and decompresses digital audio data according to a given audio file format or                                             |

|    |         |                                            |                                                                                                                                                                     |
|----|---------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |         |                                            | streaming media audio format.                                                                                                                                       |
| 12 | SD 3.0  | Security Digital 3.0                       | A non-volatile memory card format developed by the SD Card Association for use in portable devices.                                                                 |
| 13 | USB DRD | USB Dual Role Device                       | dual-role controller, which supports both Host and device functions and is full compliant with the On-The-Go Supplement to the USB 2.0 Specification, Revision 1.0a |
| 14 | EHCI    | Enhanced Host Controller Interface         | a high-speed controller standard that is publicly specified                                                                                                         |
| 15 | OHCI    | Open Host Controller Interface             | A register-level interface that enables a host controller for USB or FireWire hardware to communicate with a host controller driver in software                     |
| 16 | TP      | Touch Panel                                | A Human-Machine Interactive Interface                                                                                                                               |
| 17 | TS      | Transport Stream                           | A data stream defined by ISO13818-1, which consists of one or more programs with video and audio data.                                                              |
| 18 | LRADC   | Low Resolution Analog to Digital Converter | A module which can transfer analog signal to digital signal                                                                                                         |
| 19 | CSI     | Camera Sensor Interface                    | The hardware block that interfaces with different image sensor interfaces and provides a standard output that can be used for subsequent image processing.          |
| 20 | HDMI    | High-Definition Multimedia Interface       | A compact audio/video interface for transmitting uncompressed digital data                                                                                          |

## Table of Contents

|                                                                     |           |
|---------------------------------------------------------------------|-----------|
| <b>Revision History .....</b>                                       | <b>1</b>  |
| <b>Technical Items.....</b>                                         | <b>2</b>  |
| <b>1. A10s Introduction.....</b>                                    | <b>26</b> |
| 1.1. Features .....                                                 | 26        |
| 1.1.1. CPU .....                                                    | 26        |
| 1.1.2. GPU .....                                                    | 26        |
| 1.1.3. VPU .....                                                    | 26        |
| 1.1.4. Display Processing Ability .....                             | 26        |
| 1.1.5. Display Output Ability .....                                 | 26        |
| 1.1.6. Image Input Ability .....                                    | 27        |
| 1.1.7. Memory.....                                                  | 27        |
| 1.1.8. External Peripherals.....                                    | 27        |
| 1.1.9. System Peripherals .....                                     | 27        |
| 1.1.10. Security System .....                                       | 28        |
| 1.1.11. Package.....                                                | 28        |
| <b>2. Pin Description .....</b>                                     | <b>29</b> |
| 2.1. Pin Placement Table.....                                       | 29        |
| 2.2. Pin Detail Description.....                                    | 29        |
| <b>3. Architecture.....</b>                                         | <b>30</b> |
| 3.1. General Block Diagram .....                                    | 30        |
| 3.2. Memory Mapping.....                                            | 30        |
| <b>4. Boot System .....</b>                                         | <b>34</b> |
| 4.1. Overview .....                                                 | 34        |
| 4.2. Boot Diagram .....                                             | 34        |
| <b>5. Power Management Unit (PMU).....</b>                          | <b>35</b> |
| 5.1. Overview .....                                                 | 35        |
| 5.2. PMU Register List .....                                        | 35        |
| 5.3. PMU Register Description.....                                  | 36        |
| 5.3.1. PMU DVFS Control Register 0 .....                            | 36        |
| 5.3.2. PMU DVFS Control Register 1(Default : 0x00001010) .....      | 37        |
| 5.3.3. PMU DVFS Control Register 2 .....                            | 37        |
| 5.3.4. PMU AXI Clock Range Register0 .....                          | 38        |
| 5.3.5. PMU AXI Clock Range Register1 .....                          | 38        |
| 5.3.6. PMU DVFS Control Register 3 .....                            | 38        |
| 5.3.7. PMU DVFS TimeOut Control Register(Default : 0x00000027)..... | 38        |

---

|           |                                                                      |           |
|-----------|----------------------------------------------------------------------|-----------|
| 5.3.8.    | PMU IRQ En Register .....                                            | 39        |
| 5.3.9.    | PMU IRQ Status Register .....                                        | 40        |
| 5.3.10.   | PMU Status Register.....                                             | 41        |
| 5.3.11.   | PMU CPUVDD DCDC Control Register Address(Default : 0x00000023) ..... | 41        |
| 5.3.12.   | PMU TWI Address(Default : 0x00000068).....                           | 41        |
| 5.3.13.   | PMU CPUVDD Value(Default : 0x00000016) .....                         | 41        |
| 5.3.14.   | PMU CPUVDD Voltage Ramp Control in DVM.....                          | 42        |
| 5.3.15.   | PMU 32KHz CPUVDD Minimum Value(Default : 0x0000000C).....            | 42        |
| 5.3.16.   | PMU VF Table Register 0.....                                         | 43        |
| 5.3.17.   | PMU VF Table Register 1.....                                         | 43        |
| 5.3.18.   | PMU VF Table Register 2.....                                         | 43        |
| 5.3.19.   | PMU VF Table Register 3.....                                         | 43        |
| 5.3.20.   | PMU VF Table Register 4.....                                         | 44        |
| 5.3.21.   | PMU VF Table Register 5.....                                         | 44        |
| 5.3.22.   | PMU VF Table Register 6.....                                         | 44        |
| 5.3.23.   | PMU VF Table Register 7.....                                         | 44        |
| 5.3.24.   | PMU VF Table Register 8.....                                         | 44        |
| 5.3.25.   | PMU VF Table Register 9.....                                         | 45        |
| 5.3.26.   | PMU VF Table Register 10.....                                        | 45        |
| 5.3.27.   | PMU VF Table Register 11 .....                                       | 45        |
| 5.3.28.   | PMU VF Table Register 12.....                                        | 45        |
| 5.3.29.   | PMU VF Table Register 13.....                                        | 46        |
| 5.3.30.   | PMU VF Table Register 14.....                                        | 46        |
| 5.3.31.   | PMU VF Table Register 15.....                                        | 46        |
| 5.3.32.   | PMU VF Table Register 16.....                                        | 46        |
| 5.3.33.   | PMU VF Table Register 17.....                                        | 46        |
| 5.3.34.   | PMU VF Table Register 18.....                                        | 47        |
| 5.3.35.   | PMU VF Table Valid Register.....                                     | 47        |
| 5.3.36.   | PMU VF Table Index Register.....                                     | 48        |
| 5.3.37.   | PMU VF Table Range Register.....                                     | 48        |
| 5.3.38.   | PMU Speed Factor Register 0 .....                                    | 48        |
| 5.3.39.   | PMU Speed Factor Register 1 .....                                    | 49        |
| 5.3.40.   | PMU Speed Factor Register 2 .....                                    | 50        |
| 5.3.41.   | CPU Idle Counter Low Register (Default: 0x00000000).....             | 50        |
| 5.3.42.   | CPU Idle Counter High Register (Default: 0x00000000).....            | 51        |
| 5.3.43.   | CPU Idle Control Register (Default: 0x00000000).....                 | 51        |
| 5.3.44.   | CPU Idle Status Register (Default: 0x00000000) .....                 | 51        |
| <b>6.</b> | <b>Clock Control Module (CCM).....</b>                               | <b>53</b> |
| 6.1.      | Overview .....                                                       | 53        |
| 6.2.      | Clock Tree Diagram .....                                             | 54        |
| 6.3.      | CCM Register List .....                                              | 57        |

---

|                                                                      |    |
|----------------------------------------------------------------------|----|
| 6.4. CCM Register Description.....                                   | 58 |
| 6.4.1. PLL1-Core (Default: 0x21005000) .....                         | 58 |
| 6.4.2. PLL1-Tuning (Default: 0x0A101000) .....                       | 59 |
| 6.4.3. PLL2-Audio (Default: 0x08100010).....                         | 60 |
| 6.4.4. PLL2-Tuning (Default: 0x00000000).....                        | 60 |
| 6.4.5. PLL3-Video (Default: 0x0010D063) .....                        | 61 |
| 6.4.6. PLL4-VE (Default: 0x21081000) .....                           | 61 |
| 6.4.7. PLL5-DDR (Default: 0x11049280) .....                          | 62 |
| 6.4.8. PLL5-Tuning (Default: 0x14880000).....                        | 63 |
| 6.4.9. PLL6 (Default: 0x21009931) .....                              | 63 |
| 6.4.10. PLL7 (Default: 0x0010D063).....                              | 64 |
| 6.4.11. PLL1-Tuning2 (Default: 0x00000000) .....                     | 65 |
| 6.4.12. PLL5-Tuning2 (Default: 0x00000000) .....                     | 65 |
| 6.4.13. OSC24M (Default: 0x00138013).....                            | 66 |
| 6.4.14. CPU/AHB/APB0 Clock Ratio (Default: 0x00010010) .....         | 66 |
| 6.4.15. APB1 Clock Divide Ratio (Default: 0x00000000).....           | 67 |
| 6.4.16. AXI Module Clock Gating (Default: 0x00000000) .....          | 68 |
| 6.4.17. AHB Module Clock Gating Register 0(Default: 0x00000000)..... | 68 |
| 6.4.18. AHB Module Clock Gating Register 1(Default: 0x00000000)..... | 69 |
| 6.4.19. APB0 Module Clock Gating (Default: 0x00000000) .....         | 70 |
| 6.4.20. APB1 Module Clock Gating (Default: 0x00000000) .....         | 70 |
| 6.4.21. NAND Clock (Default: 0x00000000) .....                       | 71 |
| 6.4.22. SD0 Clock (Default: 0x00000000) .....                        | 72 |
| 6.4.23. SD1 Clock (Default: 0x00000000) .....                        | 72 |
| 6.4.24. SD2 Clock (Default: 0x00000000) .....                        | 73 |
| 6.4.25. TS Clock (Default: 0x00000000) .....                         | 73 |
| 6.4.26. SS Clock (Default: 0x00000000).....                          | 74 |
| 6.4.27. SPI0 Clock (Default: 0x00000000).....                        | 74 |
| 6.4.28. SPI1 Clock (Default: 0x00000000).....                        | 75 |
| 6.4.29. SPI2 Clock (Default: 0x00000000).....                        | 76 |
| 6.4.30. IR Clock (Default: 0x00000000) .....                         | 76 |
| 6.4.31. IIS Clock (Default: 0x00000000) .....                        | 77 |
| 6.4.32. Keypad Register (Default: 0x00000000).....                   | 77 |
| 6.4.33. USB Clock (Default: 0x00000000) .....                        | 78 |
| 6.4.34. GPS Clock (Default: 0x80000000).....                         | 79 |
| 6.4.35. DRAM CLK (Default: 0x00000000).....                          | 79 |
| 6.4.36. DE-BE Clock (Default: 0x00000000) .....                      | 80 |
| 6.4.37. DE-FE Clock(Default: 0x00000000).....                        | 80 |
| 6.4.38. LCD CH0 TVE Clock (Default: 0x00000000) .....                | 81 |
| 6.4.39. LCD CH1 Clock (Default: 0x00000000) .....                    | 82 |
| 6.4.40. CSI Clock (Default: 0x00000000) .....                        | 82 |
| 6.4.41. VE Clock (Default: 0x00000000).....                          | 83 |
| 6.4.42. Audio Codec Clock (Default: 0x00000000).....                 | 84 |

---

|            |                                                             |           |
|------------|-------------------------------------------------------------|-----------|
| 6.4.43.    | AVS Clock (Default: 0x00000000) .....                       | 84        |
| 6.4.44.    | HDMI Clock (Default: 0x00000000) .....                      | 84        |
| 6.4.45.    | Mali-400 Clock Register(Default: 0x00000000) .....          | 85        |
| 6.4.46.    | MBUS Clock Control (Default: 0x00000000) .....              | 85        |
| 6.4.47.    | IEP Clock Control (Default: 0x00000000) .....               | 86        |
| <b>7.</b>  | <b>System Control .....</b>                                 | <b>87</b> |
| 7.1.       | Overview .....                                              | 87        |
| 7.2.       | System Control Register List .....                          | 87        |
| 7.3.       | System Control Register Description .....                   | 87        |
| 7.3.1.     | SRAM Configuration Register 0(Default: 0x7FFFFFFF) .....    | 87        |
| 7.3.2.     | SRAM Configuration Register 1(Default: 0x00001000).....     | 87        |
| <b>8.</b>  | <b>CPU Control.....</b>                                     | <b>89</b> |
| 8.1.       | CPU Register List.....                                      | 89        |
| 8.2.       | CPU Control Register Description .....                      | 89        |
| 8.2.1.     | CPU Control Register(Default :0x00000002).....              | 89        |
| <b>9.</b>  | <b>SDRAM Controller.....</b>                                | <b>90</b> |
| 9.1.       | Overview .....                                              | 90        |
| <b>10.</b> | <b>Pulse Width Modulator (PWM).....</b>                     | <b>91</b> |
| 10.1.      | Overview .....                                              | 91        |
| 10.2.      | PWM Register List.....                                      | 91        |
| 10.3.      | PWM Register Description .....                              | 91        |
| 10.3.1.    | PWM Control Register (Default: 0x00000000) .....            | 91        |
| 10.3.2.    | PWM Channel 0 Period Register .....                         | 93        |
| 10.3.3.    | PWM Channel 1 Period Register .....                         | 94        |
| <b>11.</b> | <b>Asynchronous Timer.....</b>                              | <b>95</b> |
| 11.1.      | Overview .....                                              | 95        |
| 11.2.      | ASYNC Timer Register List.....                              | 95        |
| 11.3.      | ASYNC Timer Register Description .....                      | 96        |
| 11.3.1.    | ASYNC Timer IRQ Enable Register (Default: 0x00000000) ..... | 96        |
| 11.3.2.    | ASYNC Timer IRQ Status Register(Default: 0x00000000).....   | 96        |
| 11.3.3.    | ASYNC Timer 0 Control Register (Default: 0x00000004).....   | 97        |
| 11.3.4.    | ASYNC Timer 0 Interval Value Register .....                 | 98        |
| 11.3.5.    | ASYNC Timer 0 Current Value Register .....                  | 98        |
| 11.3.6.    | ASYNC Timer 1 Control Register (Default: 0x00000004).....   | 99        |
| 11.3.7.    | ASYNC Timer 1 Interval Value Register .....                 | 100       |
| 11.3.8.    | ASYNC Timer 1 Current Value Register .....                  | 100       |
| 11.3.9.    | ASYNC Timer 2 Control Register (Default: 0x00000004).....   | 100       |

---

|            |                                                             |            |
|------------|-------------------------------------------------------------|------------|
| 11.3.10.   | ASYNC Timer 2 Interval Value Register .....                 | 101        |
| 11.3.11.   | ASYNC Timer 2 Current Value Register .....                  | 101        |
| 11.3.12.   | ASYNC Timer 3 Control Register (Default: 0x00000000).....   | 102        |
| 11.3.13.   | ASYNC Timer 3 Interval Value .....                          | 102        |
| 11.3.14.   | ASYNC Timer 4 Control Register (Default: 0x00000004).....   | 102        |
| 11.3.15.   | ASYNC Timer 4 Interval Value Register .....                 | 104        |
| 11.3.16.   | ASYNC Timer 4 Current Value Register .....                  | 104        |
| 11.3.17.   | ASYNC Timer 5 Control Register (Default: 0x00000004).....   | 104        |
| 11.3.18.   | ASYNC Timer 5 Interval Value Register .....                 | 105        |
| 11.3.19.   | ASYNC Timer 5 Current Value Register .....                  | 105        |
| 11.3.20.   | AVS Counter Control Register (Default: 0x00000000) .....    | 106        |
| 11.3.21.   | AVS Counter 0 Register (Default: 0x00000000) .....          | 106        |
| 11.3.22.   | AVS Counter 1 Register (Default: 0x00000000) .....          | 107        |
| 11.3.23.   | AVS Counter Divisor Register (Default: 0x05DB05DB).....     | 107        |
| 11.3.24.   | Watchdog Control Register .....                             | 107        |
| 11.3.25.   | Watchdog Mode Register (Default: 0x00000000).....           | 108        |
| 11.3.26.   | 64-bit Counter Low Register (Default: 0x00000000) .....     | 109        |
| 11.3.27.   | 64-bit Counter High Register (Default: 0x00000000) .....    | 109        |
| 11.3.28.   | 64-bit Counter Control Register (Default: 0x00000000) ..... | 109        |
| 11.3.29.   | CPU Config Register (Default: 0x00000000).....              | 109        |
| <b>12.</b> | <b>Synchronic Timer .....</b>                               | <b>111</b> |
| 12.1.      | Overview .....                                              | 111        |
| 12.2.      | Sync Timer Register List .....                              | 111        |
| 12.3.      | Sync Timer Register Description.....                        | 111        |
| 12.3.1.    | Sync Timer IRQ Enable Register (Default: 0x00000000).....   | 111        |
| 12.3.2.    | Sync Timer IRQ Status Register(Default: 0x00000000).....    | 112        |
| 12.3.3.    | Sync Timer 0 Control Register (Default: 0x00000004).....    | 112        |
| 12.3.4.    | Sync Timer 0 Interval Value Low Register .....              | 113        |
| 12.3.5.    | Sync Timer 0 Interval Value High Register .....             | 113        |
| 12.3.6.    | Sync Timer 0 Current Value Lo Register.....                 | 113        |
| 12.3.7.    | Sync Timer 0 Current Value Hi Register .....                | 113        |
| 12.3.8.    | Sync Timer 1 Control Register (Default: 0x00000004).....    | 114        |
| 12.3.9.    | Sync Timer 1 Interval Value Low Register .....              | 115        |
| 12.3.10.   | Sync Timer 1 Interval Value High Register .....             | 115        |
| 12.3.11.   | Sync Timer 1 Current Value Low Register.....                | 115        |
| 12.3.12.   | Sync Timer 1 Current Value High Register .....              | 115        |
| <b>13.</b> | <b>Interrupt Controller .....</b>                           | <b>117</b> |
| 13.1.      | Overview .....                                              | 117        |
| 13.2.      | Interrupt Source.....                                       | 117        |
| 13.3.      | Interrupt Register List.....                                | 119        |

---

|                                                                               |            |
|-------------------------------------------------------------------------------|------------|
| 13.4. Interrupt Register Description .....                                    | 120        |
| 13.4.1. Interrupt Vector Register (Default: 0x00000000) .....                 | 120        |
| 13.4.2. Interrupt Base Address Register (Default: 0x00000000) .....           | 121        |
| 13.4.3. Interrupt Protection Register (Default: 0x00000000) .....             | 121        |
| 13.4.4. NMI Interrupt Control Register (Default: 0x00000000) .....            | 121        |
| 13.4.5. Interrupt IRQ Pending Register 0(Default: 0x00000000).....            | 121        |
| 13.4.6. Interrupt IRQ Pending Register 1(Default: 0x00000000).....            | 122        |
| 13.4.7. Interrupt IRQ Pending Register 2(Default: 0x00000000).....            | 122        |
| 13.4.8. Interrupt FIQ Pending/Clear Register 0 (Default: 0x00000000) .....    | 122        |
| 13.4.9. Interrupt FIQ Pending/Clear Register 1(Default: 0x00000000) .....     | 122        |
| 13.4.10. Interrupt FIQ Pending/Clear Register 2(Default: 0x00000000) .....    | 123        |
| 13.4.11. Interrupt Select Register 0(Default: 0x00000000) .....               | 123        |
| 13.4.12. Interrupt Select Register 1(Default: 0x00000000) .....               | 123        |
| 13.4.13. Interrupt Select Register 2(Default: 0x00000000) .....               | 123        |
| 13.4.14. Interrupt Enable Register 0(Default: 0x00000000) .....               | 123        |
| 13.4.15. Interrupt Enable Register 1(Default: 0x00000000) .....               | 124        |
| 13.4.16. Interrupt Enable Register 2(Default: 0x00000000) .....               | 124        |
| 13.4.17. Interrupt Mask Register 0(Default: 0x00000000).....                  | 124        |
| 13.4.18. Interrupt Mask Register 1(Default: 0x00000000).....                  | 124        |
| 13.4.19. Interrupt Mask Register 2(Default: 0x00000000).....                  | 125        |
| 13.4.20. Interrupt Response Register 0(Default: 0x00000000) .....             | 125        |
| 13.4.21. Interrupt Response Register 1(Default: 0x00000000) .....             | 125        |
| 13.4.22. Interrupt Response Register 2(Default: 0x00000000) .....             | 125        |
| 13.4.23. Interrupt Fast Forcing Register 0(Default: 0x00000000) .....         | 125        |
| 13.4.24. Interrupt Fast Forcing Register 1(Default: 0x00000000) .....         | 126        |
| 13.4.25. Interrupt Fast Forcing Register 2(Default: 0x00000000) .....         | 126        |
| 13.4.26. Interrupt Source Priority 0 Register (Default: 0x00000000).....      | 126        |
| 13.4.27. Interrupt Source Priority 1 Register (Default: 0x00000000).....      | 129        |
| 13.4.28. Interrupt Source Priority 2 Register (Default: 0x00000000).....      | 132        |
| 13.4.29. Interrupt Source Priority 3 Register (Default: 0x00000000).....      | 135        |
| 13.4.30. Interrupt Source Priority 4 Register (Default: 0x00000000).....      | 137        |
| 13.4.31. Interrupt Source Priority 5 Register (Default: 0x00000000).....      | 140        |
| <b>14. DMA Controller .....</b>                                               | <b>144</b> |
| 14.1. Overview .....                                                          | 144        |
| 14.2. DMA Description.....                                                    | 144        |
| 14.3. DMA Register List.....                                                  | 144        |
| 14.4. DMA Register Description .....                                          | 144        |
| 14.4.1. DMA IRQ Enable Register (Default: 0x00000000) .....                   | 144        |
| 14.4.2. DMA IRQ Pending Status Register (Default: 0x00000000) .....           | 147        |
| 14.4.3. Normal DMA Configuration Register (Default: 0x00000000) (N=0:7) ..... | 150        |
| 14.4.4. Normal DMA Source Address Register (Default: 0x00000000).....         | 153        |

---

|            |                                                                     |            |
|------------|---------------------------------------------------------------------|------------|
| 14.4.5.    | Normal DMA Destination Address Register (Default: 0x00000000) ..... | 153        |
| 14.4.6.    | Normal DMA Byte Counter Register (Default: 0x00000000) .....        | 153        |
| 14.4.7.    | Dedicated DMA Configuration Register (Default: 0x00000000) .....    | 153        |
| 14.4.8.    | Dedicated DMA Source Start Address Register (N=0:7) .....           | 157        |
| 14.4.9.    | Dedicated DMA Destination Start Address Register (N=0:7) .....      | 157        |
| 14.4.10.   | Dedicated DMA Byte Counter Register (N=0:7) .....                   | 157        |
| 14.4.11.   | Dedicated DMA Parameter Register.....                               | 157        |
| <b>15.</b> | <b>NAND Flash Controller .....</b>                                  | <b>158</b> |
| 15.1.      | Overview .....                                                      | 158        |
| 15.2.      | NFC Block Diagram .....                                             | 159        |
| 15.3.      | NFC Timing Diagram.....                                             | 159        |
| 15.4.      | NFC Operation Guide .....                                           | 164        |
| <b>16.</b> | <b>SD/MMC Controller .....</b>                                      | <b>166</b> |
| 16.1.      | Overview .....                                                      | 166        |
| 16.2.      | SD/MMC Timing Diagram .....                                         | 166        |
| <b>17.</b> | <b>Two Wire Interface .....</b>                                     | <b>167</b> |
| 17.1.      | Overview .....                                                      | 167        |
| 17.2.      | TWI Timing Diagram .....                                            | 167        |
| 17.3.      | TWI Controller Register List.....                                   | 168        |
| 17.4.      | TWI Controller Register Description .....                           | 168        |
| 17.4.1.    | TWI Slave Address Register .....                                    | 168        |
| 17.4.2.    | TWI Extend Address Register.....                                    | 169        |
| 17.4.3.    | TWI Data Register.....                                              | 169        |
| 17.4.4.    | TWI Control Register.....                                           | 169        |
| 17.4.5.    | TWI Status Register .....                                           | 171        |
| 17.4.6.    | TWI Clock Register .....                                            | 172        |
| 17.4.7.    | TWI Soft Reset Register .....                                       | 173        |
| 17.4.8.    | TWI Enhance Feature Register .....                                  | 173        |
| 17.4.9.    | TWI Line Control Register.....                                      | 173        |
| 17.4.10.   | TWI DVFS Control Register.....                                      | 174        |
| 17.5.      | TWI Controller Special Requirement .....                            | 174        |
| 17.5.1.    | TWI Pin List .....                                                  | 174        |
| 17.5.2.    | TWI Controller Operation .....                                      | 174        |
| <b>18.</b> | <b>Serial Peripheral Interface (SPI) .....</b>                      | <b>176</b> |
| 18.1.      | Overview .....                                                      | 176        |
| 18.2.      | SPI Timing Diagram .....                                            | 176        |

---

|            |                                            |            |
|------------|--------------------------------------------|------------|
| 18.3.      | SPI Register List.....                     | 177        |
| 18.4.      | SPI Register Description.....              | 178        |
| 18.4.1.    | SPI RX Data Register .....                 | 178        |
| 18.4.2.    | SPI TX Data Register.....                  | 178        |
| 18.4.3.    | SPI Control Register .....                 | 178        |
| 18.4.4.    | SPI Interrupt Control Register.....        | 180        |
| 18.4.5.    | SPI Interrupt Status Register .....        | 182        |
| 18.4.6.    | SPI DMA Control Register.....              | 184        |
| 18.4.7.    | SPI Wait Clock Register.....               | 185        |
| 18.4.8.    | SPI Clock Control Register .....           | 185        |
| 18.4.9.    | SPI Burst Counter Register.....            | 186        |
| 18.4.10.   | SPI Transmit Counter Register .....        | 186        |
| 18.4.11.   | SPI FIFO Status Register.....              | 187        |
| 18.5.      | SPI Special Requirement.....               | 187        |
| 18.5.1.    | SPI Pin List.....                          | 187        |
| 18.5.2.    | SPI Module Clock Source and Frequency..... | 187        |
| <b>19.</b> | <b>UART .....</b>                          | <b>189</b> |
| 19.1.      | Overview .....                             | 189        |
| 19.2.      | UART Timing Diagram .....                  | 189        |
| 19.3.      | UART Register List.....                    | 190        |
| 19.4.      | UART Register Description .....            | 191        |
| 19.4.1.    | UART Receiver Buffer Register .....        | 191        |
| 19.4.2.    | UART Transmit Holding Register .....       | 191        |
| 19.4.3.    | UART Divisor Latch Low Register.....       | 191        |
| 19.4.4.    | UART Divisor Latch High Register.....      | 192        |
| 19.4.5.    | UART Interrupt Enable Register .....       | 192        |
| 19.4.6.    | UART Interrupt Identity Register.....      | 193        |
| 19.4.7.    | UART FIFO Control Register .....           | 195        |
| 19.4.8.    | UART Line Control Register.....            | 196        |
| 19.4.9.    | UART Modem Control Register .....          | 197        |
| 19.4.10.   | UART Line Status Register .....            | 199        |
| 19.4.11.   | UART Modem Status Register .....           | 201        |
| 19.4.12.   | UART Scratch Register.....                 | 203        |
| 19.4.13.   | UART Status Register .....                 | 203        |
| 19.4.14.   | UART Transmit FIFO Level Register .....    | 204        |
| 19.4.15.   | UART Receive FIFO Level Register .....     | 204        |
| 19.4.16.   | UART Halt TX Register .....                | 204        |
| 19.5.      | UART Special Requirement.....              | 205        |
| 19.5.1.    | UART Pin List.....                         | 205        |
| 19.5.2.    | IrDA Inverted Signals .....                | 206        |

|                                                                |            |
|----------------------------------------------------------------|------------|
| <b>20. CIR Interface .....</b>                                 | <b>207</b> |
| 20.1. Overview .....                                           | 207        |
| 20.2. CIR Register List .....                                  | 207        |
| 20.3. CIR Register Description.....                            | 207        |
| 20.3.1. CIR Control Register .....                             | 207        |
| 20.3.2. CIR Receiver Configure Register.....                   | 208        |
| 20.3.3. CIR Receiver FIFO Register .....                       | 208        |
| 20.3.4. CIR Receiver Interrupt Control Register .....          | 208        |
| 20.3.5. CIR Receiver Status Register .....                     | 209        |
| 20.3.6. CIR Configure Register .....                           | 210        |
| <b>21. USB DRD Controller .....</b>                            | <b>212</b> |
| 21.1. Overview .....                                           | 212        |
| <b>22. USB Host Controller .....</b>                           | <b>212</b> |
| 22.1. Overview .....                                           | 212        |
| 22.2. USB Host Block Diagram .....                             | 212        |
| 22.3. USB Host Timing Diagram .....                            | 213        |
| 22.4. USB Host Register List .....                             | 213        |
| 22.5. EHCI Register Description .....                          | 214        |
| 22.5.1. EHCI Identification Register .....                     | 214        |
| 22.5.2. EHCI Host Interface Version Number Register.....       | 214        |
| 22.5.3. EHCI Host Control Structural Parameter Register.....   | 215        |
| 22.5.4. EHCI Host Control Capability Parameter Register .....  | 216        |
| 22.5.5. EHCI Companion Port Route Description.....             | 217        |
| 22.5.6. EHCI USB Command Register .....                        | 218        |
| 22.5.7. EHCI USB Status Register.....                          | 221        |
| 22.5.8. EHCI USB Interrupt Enable Register .....               | 223        |
| 22.5.9. EHCI Frame Index Register .....                        | 223        |
| 22.5.10. EHCI Periodic Frame List Base Address Register.....   | 224        |
| 22.5.11. EHCI Current Asynchronous List Address Register ..... | 225        |
| 22.5.12. EHCI Configure Flag Register .....                    | 225        |
| 22.5.13. EHCI Port Status and Control Register.....            | 225        |
| 22.6. OHCI Register Description.....                           | 230        |
| 22.6.1. HcRevision Register.....                               | 230        |
| 22.6.2. HcControl Register .....                               | 230        |
| 22.6.3. HcCommandStatus Register.....                          | 232        |
| 22.6.4. HcInterruptStatus Register.....                        | 234        |
| 22.6.5. HcInterruptEnable Register .....                       | 234        |
| 22.6.6. HcInterruptDisable Register .....                      | 235        |
| 22.6.7. HcHCCA Register.....                                   | 236        |

---

|            |                                                      |            |
|------------|------------------------------------------------------|------------|
| 22.6.8.    | HcPeriodCurrentED Register .....                     | 237        |
| 22.6.9.    | HcControlHeadED Register .....                       | 237        |
| 22.6.10.   | HcControlCurrentED Register .....                    | 237        |
| 22.6.11.   | HcBulkHeadED Register .....                          | 238        |
| 22.6.12.   | HcBulkCurrentED Register .....                       | 238        |
| 22.6.13.   | HcDoneHead Register .....                            | 239        |
| 22.6.14.   | HcFmInterval Register .....                          | 239        |
| 22.6.15.   | HcFmRemaining Register .....                         | 240        |
| 22.6.16.   | HcFmNumber Register .....                            | 240        |
| 22.6.17.   | HcPeriodicStart Register .....                       | 240        |
| 22.6.18.   | HcLSThreshold Register .....                         | 241        |
| 22.6.19.   | HcRhDescriptorA Register .....                       | 241        |
| 22.6.20.   | HcRhDescriptorB Register .....                       | 242        |
| 22.6.21.   | HcRhStatus Register .....                            | 243        |
| 22.6.22.   | HcRhPortStatus Register .....                        | 244        |
| 22.7.      | USB Host Special Requirement .....                   | 248        |
| 22.7.1.    | USB Host Clock Requirment .....                      | 248        |
| <b>23.</b> | <b>Digital Audio Interface .....</b>                 | <b>249</b> |
| 23.1.      | Overview .....                                       | 249        |
| 23.2.      | Digital Audio Block Diagram .....                    | 249        |
| 23.3.      | Digital Audio Interface Timing Diagram .....         | 250        |
| 23.4.      | Digital Audio Interface Register List .....          | 251        |
| 23.5.      | Digital Audio Interface Register Description .....   | 251        |
| 23.5.1.    | Digital Audio Control Register .....                 | 251        |
| 23.5.2.    | Digital Audio Format Register 0 .....                | 252        |
| 23.5.3.    | Digital Audio Format Register 1 .....                | 253        |
| 23.5.4.    | Digital Audio TX FIFO register .....                 | 254        |
| 23.5.5.    | Digital Audio RX FIFO register .....                 | 255        |
| 23.5.6.    | Digital Audio FIFO Control Register .....            | 255        |
| 23.5.7.    | Digital Audio FIFO Status Register .....             | 256        |
| 23.5.8.    | Digital Audio DMA & Interrupt Control Register ..... | 256        |
| 23.5.9.    | Digital Audio Interrupt Status Register .....        | 257        |
| 23.5.10.   | Digital Audio Clock Divide Register .....            | 258        |
| 23.5.11.   | Digital Audio TX Counter register .....              | 259        |
| 23.5.12.   | Digital Audio RX Counter register .....              | 259        |
| 23.5.13.   | Digital Audio TX Channel Select register .....       | 260        |
| 23.5.14.   | Digital Audio TX Channel Mapping Register .....      | 260        |
| 23.5.15.   | Digital Audio RX Channel Select register .....       | 260        |
| 23.5.16.   | Digital Audio RX Channel Mapping Register .....      | 260        |
| 23.6.      | Digital Audio Interface Special Requirement .....    | 261        |

---

|            |                                                          |            |
|------------|----------------------------------------------------------|------------|
| 23.6.1.    | Digital Audio Interface Pin List .....                   | 261        |
| 23.6.2.    | Digital Audio Interface MCLK and BCLK .....              | 261        |
| 23.6.3.    | Digital Audio Interface Clock Source and Frequency ..... | 262        |
| <b>24.</b> | <b>Ethernet MAC .....</b>                                | <b>263</b> |
| 24.1.      | Overview .....                                           | 263        |
| <b>25.</b> | <b>Transport Stream Controller .....</b>                 | <b>264</b> |
| 25.1.      | Overview .....                                           | 264        |
| 25.2.      | TS Register List.....                                    | 265        |
| 25.3.      | TS Register Description .....                            | 266        |
| 25.3.1.    | TSC Control Register .....                               | 266        |
| 25.3.2.    | TSC Status Register .....                                | 266        |
| 25.3.3.    | TSC Port Control Register .....                          | 266        |
| 25.3.4.    | TSC Port Parameter Register .....                        | 266        |
| 25.3.5.    | TSC TSF Input Multiplex Control Register.....            | 267        |
| 25.3.6.    | TSC Port Output Multiplex Control Register .....         | 267        |
| 25.3.7.    | TSG Control and Status Register .....                    | 267        |
| 25.3.8.    | TSG Packet Parameter Register .....                      | 268        |
| 25.3.9.    | TSG Interrupt Enable and Status Register .....           | 269        |
| 25.3.10.   | TSG Clock Control Register.....                          | 269        |
| 25.3.11.   | TSG Buffer Base Address Register .....                   | 269        |
| 25.3.12.   | TSG Buffer Size Register.....                            | 270        |
| 25.3.13.   | TSG Buffer Pointer Register .....                        | 270        |
| 25.3.14.   | TSF Control and Status Register .....                    | 270        |
| 25.3.15.   | TSF Packet Parameter Register .....                      | 270        |
| 25.3.16.   | TSF Interrupt Enable and Status Register.....            | 271        |
| 25.3.17.   | TSF DMA Interrupt Enable Register .....                  | 272        |
| 25.3.18.   | TSF Overlap Interrupt Enable Register .....              | 272        |
| 25.3.19.   | TSF DMA Interrupt Status Register .....                  | 272        |
| 25.3.20.   | TSF Overlap Interrupt Status Register.....               | 272        |
| 25.3.21.   | TSF PCR Control Register.....                            | 273        |
| 25.3.22.   | TSF PCR Data Register.....                               | 273        |
| 25.3.23.   | TSF Channel Enable Register .....                        | 273        |
| 25.3.24.   | TSF Channel PES Enable Register .....                    | 273        |
| 25.3.25.   | TSF Channel Descramble Enable Register.....              | 274        |
| 25.3.26.   | TSF Channel Index Register.....                          | 274        |
| 25.3.27.   | TSF Channel Control Register .....                       | 274        |
| 25.3.28.   | TSF Channel Status Register .....                        | 274        |
| 25.3.29.   | TSF Channel CW Index Register.....                       | 274        |
| 25.3.30.   | TSF Channel PID Register.....                            | 274        |
| 25.3.31.   | TSF Channel Buffer Base Address Register .....           | 275        |
| 25.3.32.   | TSF Channel Buffer Size Register.....                    | 275        |

---

---

|                                                             |            |
|-------------------------------------------------------------|------------|
| 25.3.33. TSF Channel Buffer Write Pointer Register .....    | 275        |
| 25.3.34. TSF Channel Buffer Read Pointer Register.....      | 276        |
| 25.4. TS Clock Requirement .....                            | 276        |
| <b>26. Audio Codec .....</b>                                | <b>277</b> |
| 26.1. Overview .....                                        | 277        |
| 26.2. Audio Codec Block Diagram .....                       | 277        |
| 26.3. Audio Codec Register List.....                        | 277        |
| 26.4. Audio Codec Register Description .....                | 278        |
| 26.4.1. DAC Digital Part Control Register.....              | 278        |
| 26.4.2. DAC FIFO Control Register .....                     | 278        |
| 26.4.3. DAC FIFO Status Register.....                       | 280        |
| 26.4.4. DAC TX DATA Register.....                           | 281        |
| 26.4.5. DAC Analog Control Register.....                    | 281        |
| 26.4.6. ADC FIFO Control Register .....                     | 283        |
| 26.4.7. ADC FIFO Status Register.....                       | 285        |
| 26.4.8. ADC RX DATA Register .....                          | 285        |
| 26.4.9. ADC Analog Control Register.....                    | 285        |
| 26.4.10. DAC TX Counter Register .....                      | 288        |
| 26.4.11. ADC RX Counter Register .....                      | 288        |
| <b>27. LRADC.....</b>                                       | <b>289</b> |
| 27.1. Overview .....                                        | 289        |
| 27.2. Principle of operation .....                          | 289        |
| 27.2.1. Block Diagram .....                                 | 289        |
| 27.2.2. Hold Key and General Key Function Introduction..... | 289        |
| 27.3. LRADC Register Description.....                       | 290        |
| 27.3.1. LRADC Control Register .....                        | 290        |
| 27.3.2. LRADC Interrupt Control Register .....              | 291        |
| 27.3.3. LRADC Interrupt Status Register.....                | 292        |
| 27.3.4. LRADC Data 0 Register .....                         | 294        |
| 27.3.5. LRADC Data 1 Register .....                         | 294        |
| <b>28. Touch Panel Controller .....</b>                     | <b>295</b> |
| 28.1. Overview .....                                        | 295        |
| 28.2. Typical Application Circuit .....                     | 295        |
| 28.3. Clock Tree and ADC Time.....                          | 296        |
| 28.3.1. Clock Tree .....                                    | 296        |
| 28.3.2. A/D Converton Time .....                            | 296        |
| 28.4. Principle of Operation.....                           | 297        |
| 28.4.1. The Basic Principle.....                            | 297        |

---

|            |                                                        |            |
|------------|--------------------------------------------------------|------------|
| 28.4.2.    | Single-ended Mode .....                                | 298        |
| 28.4.3.    | Differential Mode .....                                | 298        |
| 28.4.4.    | Single Touch Detection.....                            | 299        |
| 28.4.5.    | Dual Touch Detection .....                             | 299        |
| 28.4.6.    | Touch-Pressure Measurement.....                        | 300        |
| 28.4.7.    | Pen Down Detection, with Programmable Sensitivity..... | 301        |
| 28.4.8.    | Median and Averaging Filter .....                      | 301        |
| 28.5.      | TP Register List.....                                  | 303        |
| 28.6.      | TP Register Description .....                          | 303        |
| 28.6.1.    | TP Control Register 0.....                             | 303        |
| 28.6.2.    | TP control Register 1.....                             | 304        |
| 28.6.3.    | TP Control Register 2.....                             | 305        |
| 28.6.4.    | Median Filter Control Register .....                   | 306        |
| 28.6.5.    | TP Interrupt& FIFO Control Register .....              | 306        |
| 28.6.6.    | TP Interrupt& FIFO Status Register.....                | 307        |
| 28.6.7.    | TP Temperature Period Register.....                    | 308        |
| 28.6.8.    | Common Data Register.....                              | 308        |
| 28.6.9.    | TP Data Register.....                                  | 309        |
| 28.6.10.   | TP Port IO Configure Register .....                    | 309        |
| 28.6.11.   | TP Port Data Register .....                            | 310        |
| <b>29.</b> | <b>Keypad Interface .....</b>                          | <b>311</b> |
| 29.1.      | Overview .....                                         | 311        |
| 29.2.      | Keypad Interface Register List.....                    | 311        |
| 29.3.      | Keypad Interface Register Description .....            | 311        |
| 29.3.1.    | Keypad Control Register .....                          | 311        |
| 29.3.2.    | Keypad Timing Register .....                           | 312        |
| 29.3.3.    | Keypad Interrupt Configure Register .....              | 312        |
| 29.3.4.    | Keypad Interrupt Status Register.....                  | 312        |
| 29.3.5.    | Keypad Input Data Register 0 .....                     | 313        |
| 29.3.6.    | Keypad Input Data Register 1 .....                     | 313        |
| 29.4.      | Keypad Interface Special Requirement .....             | 313        |
| 29.4.1.    | Keypad Interface Pin List .....                        | 313        |
| <b>30.</b> | <b>TV Encoder (TVE).....</b>                           | <b>314</b> |
| 30.1.      | Overview .....                                         | 314        |
| 30.2.      | TVE Block Diagram.....                                 | 314        |
| 30.3.      | TV Encoder Register List .....                         | 314        |
| 30.4.      | TV Encoder Register Description.....                   | 315        |
| 30.4.1.    | TVE Global Control Register.....                       | 315        |
| 30.4.2.    | TVE Configuration Register0 .....                      | 315        |

---

|                     |                                                 |     |
|---------------------|-------------------------------------------------|-----|
| 30.4.3.             | TVE DAC Configuration Register.....             | 316 |
| 30.4.4.             | TVE Filter Register .....                       | 317 |
| 30.4.5.             | TVE Chroma Frequency Register.....              | 318 |
| 30.4.6.             | TVE Porch Num Register.....                     | 318 |
| 30.4.7.             | TVE Line Number Register .....                  | 318 |
| 30.4.8.             | TVE Black Level Register .....                  | 319 |
| 30.4.9.             | TVE Auto Detect Enable Register.....            | 319 |
| 30.4.10.            | TVE Auto Detect Interrupt Status Register ..... | 319 |
| 30.4.11.            | TVE Auto Detection Status Register.....         | 320 |
| 30.4.12.            | TVE Auto Detect de-bounce Setting Register..... | 320 |
| 30.4.13.            | TVE Color Burst Phase Reset Register .....      | 320 |
| 30.4.14.            | TVE Vsync Number Register .....                 | 320 |
| 30.4.15.            | TVE Notch Filter Frequency Register .....       | 321 |
| 30.4.16.            | TVE Cb Cr Level Register.....                   | 321 |
| 30.4.17.            | TVE Tint and Color Burst Phase Register .....   | 322 |
| 30.4.18.            | TVE Burst Width Register .....                  | 322 |
| 30.4.19.            | TVE_CBCR_GAIN_REG .....                         | 322 |
| 30.4.20.            | TVE Sync and VBI Level Register .....           | 323 |
| 30.4.21.            | TVE Sync and VBI Level Register .....           | 323 |
| 30.4.22.            | TVE Active Num Register.....                    | 323 |
| 30.4.23.            | TVE Chroma BW and CompGain Register.....        | 323 |
| 30.4.24.            | TVE Notch Width Register .....                  | 324 |
| 30.4.25.            | TVE Re-sync Num Register .....                  | 324 |
| 30.4.26.            | TVE Slave Parameter Register.....               | 325 |
| 30.4.27.            | TVE Configuration Register1 .....               | 325 |
| 30.4.28.            | TVE Configuration Register2 .....               | 325 |
| <b>31. CSI.....</b> | <b>327</b>                                      |     |
| 31.1.               | Overview .....                                  | 327 |
| 31.2.               | CSI Block Diagram.....                          | 327 |
| 31.3.               | CSI Register List .....                         | 327 |
| 31.4.               | CSI Register Description.....                   | 328 |
| 31.4.1.             | CSI Enable Register.....                        | 328 |
| 31.4.2.             | CSI Configuration Register .....                | 328 |
| 31.4.3.             | CSI Capture Control Register .....              | 330 |
| 31.4.4.             | CSI FIFO0 Buffer A Register.....                | 330 |
| 31.4.5.             | CSI FIFO0 Buffer B Register.....                | 330 |
| 31.4.6.             | CSI FIFO1 Buffer A Register.....                | 331 |
| 31.4.7.             | CSI FIFO1 Buffer B Register.....                | 331 |
| 31.4.8.             | CSI Buffer Control Register.....                | 331 |
| 31.4.9.             | CSI Status Register.....                        | 331 |
| 31.4.10.            | CSI Interrupt Enable Register .....             | 332 |

---

|            |                                          |            |
|------------|------------------------------------------|------------|
| 31.4.11.   | CSI Interrupt Status Register .....      | 333        |
| 31.4.12.   | CSI Window Width Control Register .....  | 333        |
| 31.4.13.   | CSI Window Height Control Register ..... | 334        |
| 31.4.14.   | CSI Buffer Length Register .....         | 334        |
| 31.5.      | CCIR656 Format .....                     | 334        |
| 31.5.1.    | Header Data Bit Definition.....          | 334        |
| 31.5.2.    | CCIR656 Header Decode .....              | 335        |
| 31.6.      | CSI Timing Diagram .....                 | 335        |
| <b>32.</b> | <b>Display Engine Front End .....</b>    | <b>336</b> |
| 32.1.      | Overview .....                           | 336        |
| 32.2.      | DEFE Block Diagram .....                 | 336        |
| 32.3.      | DEFE Register List.....                  | 336        |
| 32.4.      | DEFE Register Description .....          | 338        |
| 32.4.1.    | DEFE_EN_REG .....                        | 338        |
| 32.4.2.    | DEFE_FRM_CTRL_REG.....                   | 338        |
| 32.4.3.    | DEFE_BYPASS_REG.....                     | 339        |
| 32.4.4.    | DEFE_AGTH_SEL_REG .....                  | 340        |
| 32.4.5.    | DEFE_LINT_CTRL_REG.....                  | 340        |
| 32.4.6.    | DEFE_BUF_ADDR0_REG .....                 | 340        |
| 32.4.7.    | DEFE_BUF_ADDR1_REG .....                 | 341        |
| 32.4.8.    | DEFE_BUF_ADDR2_REG .....                 | 341        |
| 32.4.9.    | DEFE_FIELD_CTRL_REG .....                | 341        |
| 32.4.10.   | DEFE_TB_OFF0_REG .....                   | 342        |
| 32.4.11.   | DEFE_TB_OFF1_REG .....                   | 342        |
| 32.4.12.   | DEFE_TB_OFF2_REG .....                   | 342        |
| 32.4.13.   | DEFE_LINESTRD0_REG .....                 | 343        |
| 32.4.14.   | DEFE_LINESTRD1_REG .....                 | 343        |
| 32.4.15.   | DEFE_LINESTRD2_REG .....                 | 343        |
| 32.4.16.   | DEFE_INPUT_FMT_REG.....                  | 344        |
| 32.4.17.   | DEFE_WB_ADDR0_REG .....                  | 345        |
| 32.4.18.   | DEFE_OUTPUT_FMT_REG.....                 | 345        |
| 32.4.19.   | DEFE_INT_EN_REG .....                    | 346        |
| 32.4.20.   | DEFE_INT_STATUS_REG.....                 | 347        |
| 32.4.21.   | DEFE_STATUS_REG.....                     | 347        |
| 32.4.22.   | DEFE_CSC_COEF00_REG .....                | 348        |
| 32.4.23.   | DEFE_CSC_COEF01_REG .....                | 349        |
| 32.4.24.   | DEFE_CSC_COEF02_REG .....                | 349        |
| 32.4.25.   | DEFE_CSC_COEF03_REG .....                | 349        |
| 32.4.26.   | DEFE_CSC_COEF10_REG .....                | 349        |
| 32.4.27.   | DEFE_CSC_COEF11_REG .....                | 349        |
| 32.4.28.   | DEFE_CSC_COEF12_REG .....                | 350        |

|            |                                                         |            |
|------------|---------------------------------------------------------|------------|
| 32.4.29.   | DEFE_CSC_COEF13_REG .....                               | 350        |
| 32.4.30.   | DEFE_CSC_COEF20_REG .....                               | 350        |
| 32.4.31.   | DEFE_CSC_COEF21_REG .....                               | 350        |
| 32.4.32.   | DEFE_CSC_COEF22_REG .....                               | 351        |
| 32.4.33.   | DEFE_CSC_COEF23_REG .....                               | 351        |
| 32.4.34.   | DEFE_WB_LINESTRD_EN_REG .....                           | 351        |
| 32.4.35.   | DEFE_WB_LINESTRD0_REG .....                             | 351        |
| 32.4.36.   | DEFE_CH0_INSIZE_REG .....                               | 351        |
| 32.4.37.   | DEFE_CH0_OUTSIZE_REG .....                              | 352        |
| 32.4.38.   | DEFE_CH0_HORZFACT_REG .....                             | 352        |
| 32.4.39.   | DEFE_CH0_VERTFACT_REG .....                             | 352        |
| 32.4.40.   | DEFE_CH0_HORZPHASE_REG .....                            | 353        |
| 32.4.41.   | DEFE_CH0_VERTPHASE0_REG.....                            | 353        |
| 32.4.42.   | DEFE_CH0_VERTPHASE1_REG.....                            | 353        |
| 32.4.43.   | DEFE_CH1_INSIZE_REG .....                               | 353        |
| 32.4.44.   | DEFE_CH1_OUTSIZE_REG .....                              | 354        |
| 32.4.45.   | DEFE_CH1_HORZFACT_REG .....                             | 354        |
| 32.4.46.   | DEFE_CH1_VERTFACT_REG .....                             | 354        |
| 32.4.47.   | DEFE_CH1_HORZPHASE_REG .....                            | 355        |
| 32.4.48.   | DEFE_CH1_VERTPHASE0_REG.....                            | 355        |
| 32.4.49.   | DEFE_CH1_VERTPHASE1_REG.....                            | 355        |
| 32.4.50.   | DEFE_CH0_HORZCOEF0_REGN (N=0:31) .....                  | 355        |
| 32.4.51.   | DEFE_CH0_VERTCOEF_REGN (N=0:31) .....                   | 356        |
| 32.4.52.   | DEFE_CH1_HORZCOEF0_REGN (N=0 :31) .....                 | 356        |
| 32.4.53.   | DEFE_CH1_VERTCOEF_REGN (N=0 :31) .....                  | 356        |
| <b>33.</b> | <b>Display Engine Back End.....</b>                     | <b>358</b> |
| 33.1.      | Overview .....                                          | 358        |
| 33.2.      | DEBE Block Diagram .....                                | 359        |
| 33.3.      | DEBE Register list.....                                 | 359        |
| 33.4.      | DEBE Register Description .....                         | 360        |
| 33.4.1.    | DEBE Mode Control Register .....                        | 360        |
| 33.4.2.    | DE-Back Color Control Register .....                    | 361        |
| 33.4.3.    | DE-Back Display Size Setting Register .....             | 362        |
| 33.4.4.    | DE-Layer Size Register.....                             | 362        |
| 33.4.5.    | DE-Layer Coordinate Control Register .....              | 362        |
| 33.4.6.    | DE-Layer Frame Buffer Line Width Register .....         | 363        |
| 33.4.7.    | DE-Layer Frame Buffer Low 32 Bit Address Register ..... | 363        |
| 33.4.8.    | DE-Layer Frame Buffer High 4 Bit Address Register.....  | 364        |
| 33.4.9.    | DE-Register Buffer Control Register.....                | 364        |
| 33.4.10.   | DE-Color Key MAX Register .....                         | 364        |
| 33.4.11.   | DE-Color Key MIN Register .....                         | 365        |

---

|            |                                                     |            |
|------------|-----------------------------------------------------|------------|
| 33.4.12.   | DE-Color Key Configuration Register .....           | 365        |
| 33.4.13.   | DE-Layer Attribute Control Register0.....           | 366        |
| 33.4.14.   | DE-Layer Attribute Control Register1.....           | 367        |
| 33.4.15.   | Pixels Sequence Table .....                         | 369        |
| 33.4.16.   | DE-HWC Coordinate Control Register.....             | 372        |
| 33.4.17.   | DE-HWC Frame Buffer Format Register .....           | 372        |
| 33.4.18.   | DEBE Write Back Control Register.....               | 373        |
| 33.4.19.   | DEBE Write Back Address Register .....              | 374        |
| 33.4.20.   | DEBE Write Back Buffer Line Width Register.....     | 374        |
| 33.4.21.   | DEBE Input YUV Channel Control Register .....       | 374        |
| 33.4.22.   | DEBE YUV Channel Frame Buffer Address Register..... | 375        |
| 33.4.23.   | DEBE YUV Channel Buffer Line Width Register .....   | 376        |
| 33.4.24.   | DEBE Y/G Coefficient Register.....                  | 376        |
| 33.4.25.   | DEBE Y/G Constant Register .....                    | 377        |
| 33.4.26.   | DEBE U/R Coefficient Register.....                  | 377        |
| 33.4.27.   | DEBE U/R Constant Register .....                    | 377        |
| 33.4.28.   | DEBE V/B Coefficient Register .....                 | 377        |
| 33.4.29.   | DEBE V/B Constant Register.....                     | 378        |
| 33.4.30.   | DEBE Output Color Control Register.....             | 378        |
| 33.4.31.   | DEBE Output Color R Coefficient Register.....       | 379        |
| 33.4.32.   | DEBE Output Color R Constant Register .....         | 379        |
| 33.4.33.   | DEBE Output Color G Coefficient Register.....       | 379        |
| 33.4.34.   | DEBE Output Color G Constant Register .....         | 379        |
| 33.4.35.   | DEBE Output Color B Coefficient Register .....      | 380        |
| 33.4.36.   | DEBE Output Color B Constant Register .....         | 380        |
| 33.4.37.   | DE-HWC Pattern Memory Block.....                    | 380        |
| 33.4.38.   | DE-HWC Palette Table.....                           | 381        |
| 33.4.39.   | Palette Mode .....                                  | 382        |
| 33.4.40.   | Internal Frame Buffer Mode .....                    | 383        |
| 33.4.41.   | Internal Frame Buffer Mode Palette Table .....      | 383        |
| 33.4.42.   | Gamma Correction Mode.....                          | 384        |
| 33.5.      | Display Engine Memory Mapping .....                 | 386        |
| <b>34.</b> | <b>HDMI Controller .....</b>                        | <b>387</b> |
| 34.1.      | Overview .....                                      | 387        |
| 34.2.      | HDMI Block Diagram.....                             | 388        |
| 34.3.      | HDMI Control Register List .....                    | 388        |
| 34.4.      | HDMI Control Register Description.....              | 389        |
| 34.4.1.    | System Control Register .....                       | 389        |
| 34.4.2.    | Interrupt Status Register .....                     | 390        |
| 34.4.3.    | HDMI Hot Plug Register.....                         | 391        |
| 34.4.4.    | Video Control Register .....                        | 391        |

|            |                                       |            |
|------------|---------------------------------------|------------|
| 34.4.5.    | Video Timing Register0 .....          | 392        |
| 34.4.6.    | Video Timing Register1 .....          | 393        |
| 34.4.7.    | Video Timing Register2 .....          | 393        |
| 34.4.8.    | Video Timing Register3 .....          | 393        |
| 34.4.9.    | Video Timing Register4 .....          | 393        |
| 34.4.10.   | Audio Control Register .....          | 394        |
| 34.4.11.   | Audio DMA&FIFO control Register ..... | 394        |
| 34.4.12.   | Audio Format Control Register.....    | 395        |
| 34.4.13.   | Audio PCM Control Register .....      | 396        |
| 34.4.14.   | Audio CTS register.....               | 398        |
| 34.4.15.   | Audio N register.....                 | 398        |
| 34.4.16.   | Audio PCM channel Status 0 .....      | 398        |
| 34.4.17.   | Audio PCM channel Status 1 .....      | 400        |
| 34.4.18.   | AVI_INFO_FRMAE_PACKET .....           | 401        |
| 34.4.19.   | AUDIO_INFO_FRMAE_PACKET .....         | 402        |
| 34.4.20.   | ACP_PACKET .....                      | 403        |
| 34.4.21.   | General_Control_PACKET.....           | 403        |
| 34.4.22.   | SPD_PACKET .....                      | 404        |
| 34.4.23.   | PLL/DRV Setting 0: Pad Ctrl0 .....    | 404        |
| 34.4.24.   | PLL/DRV Setting 1: Pad Ctrl1 .....    | 405        |
| 34.4.25.   | PLL/DRV Setting 2: PLL Ctrl0 .....    | 405        |
| 34.4.26.   | PLL/DRV Setting 5: HPD/CEC.....       | 406        |
| 34.4.27.   | PACKET_Control 0.....                 | 406        |
| 34.4.28.   | PACKET Control 1.....                 | 408        |
| 34.4.29.   | Audio Normal DMA Port .....           | 411        |
| 34.4.30.   | DDC Control Register .....            | 411        |
| 34.4.31.   | DDC Slave Address Register.....       | 411        |
| 34.4.32.   | DDC Interrupt Mask Register.....      | 412        |
| 34.4.33.   | DDC Interrupt Status Register .....   | 412        |
| 34.4.34.   | DDC FIFO Control Register .....       | 413        |
| 34.4.35.   | DDC FIFO Status Register.....         | 414        |
| 34.4.36.   | DDC FIFO Access Register .....        | 414        |
| 34.4.37.   | DDC Access Data Byte Number .....     | 414        |
| 34.4.38.   | DDC Access Command Register.....      | 414        |
| 34.4.39.   | DDC Extended Register.....            | 415        |
| 34.4.40.   | DDC Clock Register .....              | 415        |
| <b>35.</b> | <b>TCON .....</b>                     | <b>417</b> |
| 35.1.      | TCON Block Diagram.....               | 417        |
| 35.2.      | TCON Register List .....              | 417        |
| 35.3.      | TCON Register Description.....        | 419        |
| 35.3.1.    | TCON_GCTL_REG.....                    | 419        |
| 35.3.2.    | TCON_GINT0_REG.....                   | 419        |

---

|            |                                               |            |
|------------|-----------------------------------------------|------------|
| 35.3.3.    | TCON_GINT1_REG.....                           | 420        |
| 35.3.4.    | TCON0_FRM_CTL_REG.....                        | 420        |
| 35.3.5.    | TCON0_FRM_SEED_REG.....                       | 421        |
| 35.3.6.    | TCON0_FRM_TAB_REG.....                        | 421        |
| 35.3.7.    | TCON0_CTL_REG.....                            | 421        |
| 35.3.8.    | TCON0_DCLK REG.....                           | 422        |
| 35.3.9.    | TCON0_BASIC0_REG .....                        | 423        |
| 35.3.10.   | TCON0_BASIC1_REG .....                        | 423        |
| 35.3.11.   | TCON0_BASIC2_REG .....                        | 423        |
| 35.3.12.   | TCON0_BASIC3_REG .....                        | 423        |
| 35.3.13.   | TCON0_HV_IF_REG .....                         | 424        |
| 35.3.14.   | TCON0_CPU_IF_REG .....                        | 425        |
| 35.3.15.   | TCON0_CPU_WR_REG.....                         | 425        |
| 35.3.16.   | TCON0_CPU_RD0_REG .....                       | 426        |
| 35.3.17.   | TCON0_CPU_RD1_REG .....                       | 426        |
| 35.3.18.   | TCON0_IO_POL_REG .....                        | 426        |
| 35.3.19.   | TCON0_IO_TRI_REG.....                         | 427        |
| 35.3.20.   | TCON1_CTL_REG.....                            | 427        |
| 35.3.21.   | TCON1_BASIC0_REG .....                        | 428        |
| 35.3.22.   | TCON1_BASIC1_REG .....                        | 428        |
| 35.3.23.   | TCON1_BASIC2_REG .....                        | 428        |
| 35.3.24.   | TCON1_BASIC3_REG .....                        | 428        |
| 35.3.25.   | TCON1_BASIC4_REG .....                        | 429        |
| 35.3.26.   | TCON1_BASIC5_REG .....                        | 429        |
| 35.3.27.   | TCON1_IO_POL_REG .....                        | 429        |
| 35.3.28.   | TCON1_IO_TRI_REG.....                         | 430        |
| 35.3.29.   | TCON_CEU_CTL_REG.....                         | 430        |
| 35.3.30.   | TCON_CEU_COEF_REG.....                        | 431        |
| 35.3.31.   | TCON1_FILL_CTL_REG .....                      | 431        |
| 35.3.32.   | TCON1_FILL_BEGIN_REG .....                    | 431        |
| 35.3.33.   | TCON1_FILL_END_REG .....                      | 432        |
| 35.3.34.   | TCON1_FILL_DATA_REG .....                     | 432        |
| <b>36.</b> | <b>Image Enhancement Processor .....</b>      | <b>433</b> |
| 36.1.      | Overview .....                                | 433        |
| 36.2.      | IEP Register Description.....                 | 433        |
| 36.2.1.    | General Control Register .....                | 433        |
| 36.2.2.    | DRC Size Setting Register.....                | 433        |
| 36.2.3.    | DRC Control Register .....                    | 434        |
| 36.2.4.    | DRC External LGC Start Address Register ..... | 434        |
| 36.2.5.    | DRC Setting Register.....                     | 434        |
| 36.2.6.    | DRC Window Position Register0 .....           | 435        |
| 36.2.7.    | DRC Window Position Register1 .....           | 435        |

---

|            |                                                                 |            |
|------------|-----------------------------------------------------------------|------------|
| 36.2.8.    | DRC Write Back Control Register .....                           | 436        |
| 36.2.9.    | DRC Write Back Address Register .....                           | 436        |
| 36.2.10.   | DRC Write Back Buffer Line Width Register.....                  | 437        |
| 36.2.11.   | Luminance Histogram Control Register.....                       | 437        |
| 36.2.12.   | Luminance Histogram Threshold Setting Register 0 .....          | 437        |
| 36.2.13.   | Luminance Histogram Threshold Setting Register 1 .....          | 437        |
| 36.2.14.   | Luminance Histogram Statistics Lum Recording Register .....     | 438        |
| 36.2.15.   | Luminance Histogram Statistics Counter Recording Register ..... | 438        |
| 36.2.16.   | CSC Y/G Coefficient Register .....                              | 438        |
| 36.2.17.   | CSC Y/G Constant Register.....                                  | 439        |
| 36.2.18.   | CSC U/R Coefficient Register .....                              | 439        |
| 36.2.19.   | CSC U/R Constant Register.....                                  | 439        |
| 36.2.20.   | CSC V/B Coefficient Register .....                              | 439        |
| 36.2.21.   | CSC V/B Constant Register .....                                 | 440        |
| 36.2.22.   | DRC Spatial Coefficient .....                                   | 440        |
| 36.2.23.   | DRC Intensity Coefficient .....                                 | 440        |
| 36.2.24.   | DRC Luminance Gain Coefficient .....                            | 440        |
| <b>37.</b> | <b>Security System (SS) .....</b>                               | <b>442</b> |
| 37.1.      | Overview .....                                                  | 442        |
| 37.2.      | Security System Block Diagram.....                              | 442        |
| 37.3.      | Security System Register List .....                             | 442        |
| 37.4.      | Security System Register Description .....                      | 443        |
| 37.4.1.    | Security System Control Register .....                          | 443        |
| 37.4.2.    | Security System Key [n] Register .....                          | 444        |
| 37.4.3.    | Security System IV[n] Register .....                            | 445        |
| 37.4.4.    | Security System Counter[n] Register.....                        | 445        |
| 37.4.5.    | Security System FIFO Control/ Status Register .....             | 445        |
| 37.4.6.    | Security System Interrupt Control/ Status Register .....        | 446        |
| 37.4.7.    | Security System Message Digest[n] Register.....                 | 446        |
| 37.4.8.    | Security System RX FIFO Register .....                          | 446        |
| 37.4.9.    | Security System TX FIFO Register.....                           | 447        |
| 37.5.      | Security System Clock Requirement .....                         | 447        |
| 37.6.      | Security System Programming Guide.....                          | 447        |
| <b>38.</b> | <b>Security ID .....</b>                                        | <b>448</b> |
| 38.1.      | Overview .....                                                  | 448        |
| 38.2.      | Security ID Register List.....                                  | 448        |
| 38.3.      | Security ID Register Description .....                          | 448        |
| 38.3.1.    | SID Root Key 0 Register .....                                   | 448        |
| 38.3.2.    | SID Root Key 1 Register .....                                   | 448        |

---

|            |                                    |            |
|------------|------------------------------------|------------|
| 38.3.3.    | SID Root Key 2 Register .....      | 448        |
| 38.3.4.    | SID Root Key 3 Register .....      | 449        |
| 38.3.5.    | SID Program Control Register ..... | 449        |
| <b>39.</b> | <b>GPS Engine.....</b>             | <b>450</b> |
| 39.1.      | Overview .....                     | 450        |
| 39.2.      | GPS Engine Register List .....     | 450        |
| <b>40.</b> | <b>Port Controller .....</b>       | <b>451</b> |
| 40.1.      | Overview .....                     | 451        |
| 40.2.      | Port Configuration Table.....      | 451        |
| 40.3.      | Port Register List.....            | 454        |
| 40.4.      | Port Register Description .....    | 454        |
| 40.4.1.    | PA Configure Register 0 .....      | 454        |
| 40.4.2.    | PA Configure Register 1 .....      | 456        |
| 40.4.3.    | PA Configure Register 2 .....      | 457        |
| 40.4.4.    | PA Configure Register 3 .....      | 457        |
| 40.4.5.    | PA Data Register .....             | 457        |
| 40.4.6.    | PA Multi-Driving Register 0 .....  | 458        |
| 40.4.7.    | PA Multi-Driving Register 1 .....  | 458        |
| 40.4.8.    | PA Pull Register 0.....            | 458        |
| 40.4.9.    | PA Pull Register 1.....            | 458        |
| 40.4.10.   | PB Configure Register 0 .....      | 459        |
| 40.4.11.   | PB Configure Register 1 .....      | 460        |
| 40.4.12.   | PB Configure Register 2 .....      | 461        |
| 40.4.13.   | PB Configure Register 3 .....      | 462        |
| 40.4.14.   | PB Data Register.....              | 462        |
| 40.4.15.   | PB Multi-Driving Register 0 .....  | 462        |
| 40.4.16.   | PB Multi-Driving Register 1 .....  | 462        |
| 40.4.17.   | PB Pull Register 0 .....           | 463        |
| 40.4.18.   | PB Pull Register 1 .....           | 463        |
| 40.4.19.   | PC Configure Register 0 .....      | 463        |
| 40.4.20.   | PC Configure Register 1 .....      | 464        |
| 40.4.21.   | PC Configure Register 2 .....      | 466        |
| 40.4.22.   | PC Configure Register 3 .....      | 466        |
| 40.4.23.   | PC Data Register .....             | 466        |
| 40.4.24.   | PC Multi-Driving Register 0 .....  | 467        |
| 40.4.25.   | PC Multi-Driving Register 1 .....  | 467        |
| 40.4.26.   | PC Pull Register 0 .....           | 467        |
| 40.4.27.   | PC Pull Register 1 .....           | 467        |
| 40.4.28.   | PD Configure Register 0 .....      | 467        |
| 40.4.29.   | PD Configure Register 1 .....      | 469        |

---

|            |                                          |            |
|------------|------------------------------------------|------------|
| 40.4.30.   | PD Configure Register 2 .....            | 470        |
| 40.4.31.   | PD Configure Register 3 .....            | 471        |
| 40.4.32.   | PD Data Register .....                   | 472        |
| 40.4.33.   | PD Multi-Driving Register 0.....         | 472        |
| 40.4.34.   | PD Multi-Driving Register 1.....         | 472        |
| 40.4.35.   | PD Pull Register 0 .....                 | 473        |
| 40.4.36.   | PD Pull Register 1 .....                 | 473        |
| 40.4.37.   | PE Configure Register 0 .....            | 473        |
| 40.4.38.   | PE Configure Register 1 .....            | 474        |
| 40.4.39.   | PE Configure Register 2 .....            | 475        |
| 40.4.40.   | PE Configure Register 3 .....            | 475        |
| 40.4.41.   | PE Data Register.....                    | 475        |
| 40.4.42.   | PE Multi-Driving Register 0.....         | 475        |
| 40.4.43.   | PE Multi-Driving Register 1.....         | 476        |
| 40.4.44.   | PE Pull Register 0 .....                 | 476        |
| 40.4.45.   | PE Pull Register 1 .....                 | 476        |
| 40.4.46.   | PF Configure Register 0.....             | 476        |
| 40.4.47.   | PF Configure Register 1.....             | 477        |
| 40.4.48.   | PF Configure Register 2.....             | 477        |
| 40.4.49.   | PF Configure Register 3.....             | 477        |
| 40.4.50.   | PF Data Register.....                    | 478        |
| 40.4.51.   | PF Multi-Driving Register 0 .....        | 478        |
| 40.4.52.   | PF Multi-Driving Register 1 .....        | 478        |
| 40.4.53.   | PF Pull Register 0 .....                 | 478        |
| 40.4.54.   | PF Pull Register 1 .....                 | 478        |
| 40.4.55.   | PG Configure Register 0.....             | 479        |
| 40.4.56.   | PG Configure Register 1 .....            | 480        |
| 40.4.57.   | PG Configure Register 2 .....            | 481        |
| 40.4.58.   | PG Configure Register 3 .....            | 481        |
| 40.4.59.   | PG Data Register .....                   | 481        |
| 40.4.60.   | PG Multi-Driving Register 0.....         | 481        |
| 40.4.61.   | PG Multi-Driving Register 1.....         | 482        |
| 40.4.62.   | PG Pull Register 0 .....                 | 482        |
| 40.4.63.   | PG Pull Register 1 .....                 | 482        |
| 40.4.64.   | PIO Interrupt Configure Register 0 ..... | 482        |
| 40.4.65.   | PIO Interrupt Configure Register 1 ..... | 482        |
| 40.4.66.   | PIO Interrupt Configure Register 2 ..... | 483        |
| 40.4.67.   | PIO Interrupt Configure Register 3 ..... | 483        |
| 40.4.68.   | PIO Interrupt Control Register .....     | 483        |
| 40.4.69.   | PIO Interrupt Status Register .....      | 483        |
| 40.4.70.   | PIO Interrupt Debounce Register.....     | 484        |
| <b>41.</b> | <b>Declaration.....</b>                  | <b>485</b> |

# 1. A10s Introduction

## 1.1. Features

### 1.1.1. CPU

- ARM Cortex-A8 Core
- 32KB I-Cache,32KB D-Cache
- 256KB L2 Cache
- NEON™ SIMD Coprocessor
- Jazelle RCT Acceleration

### 1.1.2. GPU

3D Graphic Engine

- Support OpenGL ES 1.1/ 2.0 and OpenVG 1.1

### 1.1.3. VPU

- Video Decoding (FULL HD)
  - Support multi-format video, including VP8, AVS, H.264, H.263, VC-1, MPEG-1/2/4
  - Up to 1920\*1080@30fps
- Video Encoding
  - Support encoding in H.264 MP format
  - Up to 1920\*1080@30fps

### 1.1.4. Display Processing Ability

- Four moveable and size-adjustable layers
- Support multi-format image input
- Support image enhancement processor
- Support alpha blending / anti-flicker
- Support hardware cursor
- Support output color correction (luminance / hue / saturation etc)

### 1.1.5. Display Output Ability

- Support HDMI V1.3
- LCD interface (CPU / Sync RGB )
- Support CVBS

### 1.1.6. Image Input Ability

- Camera sensor interface (CSI)
- 8 bits input data
- Support CCIR656 protocol for NTSC and PAL

### 1.1.7. Memory

- 32-bit SDRAM controller
  - Support DDR2 SDRAM and DDR3 SDRAM up to 533MHz
  - Memory capacity up to 16 G-bits
- 8-bit NAND Flash Controller with 4 CE and 2RB signals
  - Support SLC/MLC/TLC/DDR NAND
  - Support 64-bit ECC

### 1.1.8. External Peripherals

- One USB 2.0 DRD(Dual-Role Device) controller for general application and one USB EHCI/OHCI controller for host application
- Three high-speed memory controllers supporting SD version 2.0 and eMMC version 4.3
- Four UARTs:UART0 is 2-wire,UART1 is 8-wire,UART2 and UART3 are 4-wire
- Three SPI controllers
- Three Two-Wire Interface(TWI) Controllers
- Key matrix (8x8) with internal debounce filter
- IR controller supporting CIR remoter
- One embedded TS SPI/SSI for DTV application
- One 10/100Mbps Ethernet MAC
- 2-channel 6-bit LRADC for line control
- Internal 4-wire touch panel controller with pressure sensor and 2-point touch
- I2S/PCM controller for 2-channel output
- Internal 24-bit Audio Codec for 2-channel headphone, 2-channel microphone, and stereo FM input
- Embedded GPS baseband

### 1.1.9. System Peripherals

- 8-channel normal DMA and 8 channel dedicated DMA
- Internal 48KB SRAM on chip
- 6 asynchronous timers, 2 synchronous timers, 1 watchdog, and 2 AVS counters
- 2-ch PWM controller

### 1.1.10. Security System

- Support DES/3DES/AES encryption and decryption
- Support SHA-1, MD5 message digest
- Support 160-bit hardware PRNG with 192-bit seed
- 128-bit EFUSE chip ID

### 1.1.11. Package

- TFBGA 336 package

## 2. Pin Description

### 2.1. Pin Placement Table

- Refer to A10s Datasheet for details.

### 2.2. Pin Detail Description

- Refer to A10s Datasheet for details.

### 3. Architecture

#### 3.1. General Block Diagram



Figure3-1 General Block Diagram

#### 3.2. Memory Mapping

| Module    | Address                   | Size(Bytes) |
|-----------|---------------------------|-------------|
| SRAM A1   | 0x0000 0000---0x0000 3FFF | 16K         |
| SRAM A2   | 0x0000 4000---0x0000 7FFF | 16K         |
| SRAM A3   | 0x0000 8000---0x0000 B3FF | 13K         |
| SRAM A4   | 0x0000 B400---0x0000 BFFF | 3K          |
| SRAM NAND | /                         | 2K          |

|                 |                           |    |
|-----------------|---------------------------|----|
| SRAM D          | 0x0001 0000---0x0001 0FFF | 4K |
| SRAM Controller | 0x01C0 0000---0x01C0 0FFF | 4K |
| DRAM Controller | 0x01C0 1000---0x01C0 1FFF | 4K |
| DMA             | 0x01C0 2000---0x01C0 2FFF | 4K |
| NFC             | 0x01C0 3000---0x01C0 3FFF | 4K |
| TS              | 0x01C0 4000---0x01C0 4FFF | 4K |
| SPI 0           | 0x01C0 5000---0x01C0 5FFF | 4K |
| SPI 1           | 0x01C0 6000---0x01C0 6FFF | 4K |
| /               | 0x01C0 7000---0x01C0 7FFF | 4K |
| /               | 0x01C0 8000---0x01C0 8FFF | 4K |
| CSI             | 0x01C0 9000---0x01C0 9FFF | 4K |
| TVE             | 0x01C0 A000---0x01C0 AFFF | 4K |
| EMAC            | 0x01C0 B000---0x01C0 BFFF | 4K |
| LCD             | 0x01C0 C000---0x01C0 CFFF | 4K |
| /               | 0x01C0 D000---0x01C0 DFFF | 4K |
| VE              | 0x01C0 E000---0x01C0 EFFF | 4K |
| SD/MMC 0        | 0x01C0 F000---0x01C0 FFFF | 4K |
| SD/MMC 1        | 0x01C1 0000---0x01C1 0FFF | 4K |
| SD/MMC 2        | 0x01C1 1000---0x01C1 1FFF | 4K |
| /               | 0x01C1 2000---0x01C1 2FFF | 4K |
| USB DRD         | 0x01C1 3000---0x01C1 3FFF | 4K |
| USB HCI         | 0x01C1 4000---0x01C1 4FFF | 4K |
| SS              | 0x01C1 5000---0x01C1 5FFF | 4K |
| HDMI            | 0x01C1 6000---0x01C1 6FFF | 4K |
| SPI 2           | 0x01C1 7000---0x01C1 7FFF | 4K |
| /               | 0x01C1 8000---0x01C1 8FFF | 4K |
| /               | 0x01C1 9000---0x01C1 9FFF | 4K |
| /               | 0x01C1 A000---0x01C1 AFFF | 4K |
| /               | 0x01C1 B000---0x01C1 BFFF | 4K |
| /               | 0x01C1 C000---0x01C1 CFFF | 4K |
| /               | 0x01C1 D000---0x01C1 DFFF | 4K |
| /               | 0x01C1 E000---0x01C1 EFFF | 4K |
| /               | 0x01C1 F000---0x01C1 FFFF | 4K |
| CCM             | 0x01C2 0000---0x01C2 03FF | 1K |
| INTC            | 0x01C2 0400---0x01C2 07FF | 1K |
| PIO             | 0x01C2 0800---0x01C2 0BFF | 1K |
| Timer           | 0x01C2 0C00---0x01C2 0FFF | 1K |
| /               | 0x01C2 1000---0x01C2 13FF | 1K |
| /               | 0x01C2 1400---0x01C2 17FF | 1K |
| IR              | 0x01C2 1800---0x01C2 1BFF | 1K |
| /               | 0x01C2 1C00---0x01C2 1FFF | 1K |
| /               | 0x01C2 2000---0x01C2 23FF | 1K |

|             |                           |    |
|-------------|---------------------------|----|
| IIS         | 0x01C2 2400---0x01C2 27FF | 1K |
| LRADC       | 0x01C2 2800---0x01C2 2BFF | 1K |
| AD/DA       | 0x01C2 2C00---0x01C2 2FFF | 1K |
| KEYPAD      | 0x01C2 3000---0x01C2 33FF | 1K |
| CPU Control | 0x01C2 3400---0x01C2 37FF | 1K |
| SID         | 0x01C2 3800---0x01C2 3BFF | 1K |
| /           | 0x01C2 3C00---0x01C2 3FFF | 1K |
| /           | 0x01C2 4000---0x01C2 43FF | 1K |
| /           | 0x01C2 4400---0x01C2 47FF | 1K |
| /           | 0x01C2 4800---0x01C2 4BFF | 1K |
| /           | 0x01C2 4C00---0x01C2 4FFF | 1K |
| TP          | 0x01C2 5000---0x01C2 53FF | 1K |
| PMU         | 0x01C2 5400---0x01C2 57FF | 1K |
| /           | 0x01C2 5800---0x01C2 5BFF | 1K |
| /           | 0x01C2 5C00---0x01C2 5FFF | 1K |
| /           | 0x01C2 6000---0x01C2 63FF | 1K |
| /           | 0x01C2 6400---0x01C2 67FF | 1K |
| /           | 0x01C2 6800---0x01C2 6BFF | 1K |
| /           | 0x01C2 6C00---0x01C2 6FFF | 1K |
| /           | 0x01C2 7000---0x01C2 73FF | 1K |
| /           | 0x01C2 7400---0x01C2 77FF | 1K |
| /           | 0x01C2 7800---0x01C2 7BFF | 1K |
| /           | 0x01C2 7C00---0x01C2 7FFF | 1K |
| UART 0      | 0x01C2 8000---0x01C2 83FF | 1K |
| UART 1      | 0x01C2 8400---0x01C2 87FF | 1K |
| UART 2      | 0x01C2 8800---0x01C2 8BFF | 1K |
| UART 3      | 0x01C2 8C00---0x01C2 8FFF | 1K |
| /           | 0x01C2 9000---0x01C2 93FF | 1K |
| /           | 0x01C2 9400---0x01C2 97FF | 1K |
| /           | 0x01C2 9800---0x01C2 9BFF | 1K |
| /           | 0x01C2 9C00---0x01C2 9FFF | 1K |
| /           | 0x01C2 A000---0x01C2 A3FF | 1K |
| /           | 0x01C2 A300---0x01C2 A7FF | 1K |
| /           | 0x01C2 A800---0x01C2 ABFF | 1K |
| TWI 0       | 0x01C2 AC00---0x01C2 AFFF | 1K |
| TWI 1       | 0x01C2 B000---0x01C2 B3FF | 1K |
| /           | 0x01C2 B400---0x01C2 B7FF | 1K |
| /           | 0x01C2 B800---0x01C2 BBFF | 1K |
| /           | 0x01C2 BC00---0x01C2 BFFF | 1K |
| /           | 0x01C2 C000---0x01C2 C3FF | 1K |
| /           | 0x01C2 C400---0x01C2 C7FF | 1K |
| /           | 0x01C2 C800---0x01C2 CBFF | 1K |

|                |                           |             |
|----------------|---------------------------|-------------|
| /              | 0x01C2 CC00---0x01C2 CFFF | 1K          |
| GPS            | 0x01C3 0000---0x01C3 FFFF | 64K         |
| Mali-400       | 0x01C4 0000---0x01C4 FFFF | 64K         |
| Sync Timer     | 0x01C6 0000—0x01C6 0FFF   | 4K          |
| SRAM C         | 0x01D0 0000---0x01DF FFFF | Module SRAM |
| DE_FE          | 0x01E0 0000---0x01E1 FFFF | 128K        |
| /              | 0x01E2 0000---0x01E3 FFFF | 128K        |
| DE_BE          | 0x01E6 0000---0x01E6 FFFF | 64K         |
| IEP            | 0x01E7 0000---0x01E7 FFFF | 64K         |
| /              | 0x01E4 0000---0x01E5 FFFF | 128K        |
| /              | 0x01E8 0000---0x01E9 FFFF | 128K        |
| /              | 0x01EA 0000---0x01EB FFFF | 128K        |
| /              | 0x3F50 0000---0x3F50 FFFF | 64K         |
| DDR-II/DDR-III | 0x4000 0000---0xBFFF FFFF | 2G          |
| BROM           | 0xFFFF 0000—0xFFFF 7FFF   | 32K         |

## 4. Boot System

### 4.1. Overview

With one 32KB ROM, the A10s supports five boot methods. The system can boot sequentially from NAND Flash, SPI NOR Flash, SD Card and USB. However, if the external boot select pin(BSP), which is pulled up by an internal 50K resistor in normal state, is checked by boot code to be on low-level state after system power-on, the system will directly jump to boot from USB.

### 4.2. Boot Diagram



Figure 4 Boot Diagram

## 5. Power Management Unit (PMU)

### 5.1. Overview

The Power Management Unit (PMU) aims to reduce dynamic power consumption and static leakage current to extend the life of batteries in end products. This module is the central control module for CPU clock and power management signals in the device.

### 5.2. PMU Register List

| Module Name | Base Address |            |
|-------------|--------------|------------|
| PMU         |              | 0x01C25400 |

| Register Name             | Offset | Description                       |
|---------------------------|--------|-----------------------------------|
| PMU_DVFS_CTRL_REG0        | 0x0000 | PMU Control Register 0            |
| PMU_DVFS_CTRL_REG1        | 0x0004 | PMU Control Register 1            |
| /                         | 0x0008 | /                                 |
| PMU_DVFS_CTRL_REG2        | 0x000C | PMU Control Register 2            |
| /                         | 0x0010 | /                                 |
| /                         | 0x0014 | /                                 |
| PMU_DVFS_CTRL_REG3        | 0x0018 | PMU Control Register 3            |
| PMU_DVFS_TIMEOUT_CTRL_REG | 0x001C | PMU Timeout Control Register      |
| PMU_AXI_AUTO_SWT_REG0     | 0x0020 | PMU AXI Auto Switch CLK Register0 |
| PMU_AXI_AUTO_SWT_REG1     | 0x0024 | PMU AXI Auto Switch CLK Register1 |
| PMU_IRQ_EN_REG            | 0x0040 | PMU IRQ Enable Register           |
| PMU_IRQ_STATUS_REG        | 0x0044 | PMU IRQ Status Register           |
| PMU_STATUS_REG            | 0x0048 | PMU Status Register               |
| PMU_CPUVDD_CTRL_REG_ADDR  | 0x004C | PMU CPUVDD Register Address       |
| PMU_TWI_ADDR_REG          | 0x0050 | PMU TWI Address                   |
| PMU_CPUVDD_VALUE_REG      | 0x0054 | PMU Cpuvdd Value                  |
| PMU_CPUVDD_RAMP_CTRL_REG  | 0x0058 | PMU CPUVDD Voltage Ramp Control   |
| PMU_32KHZ_CPUVDD_MIN_REG  | 0x005C | PMU 32khz CPUVDD Minimum Value    |
| PMU_VF_TABLE_REG0         | 0x0080 | CPU speed max if the vddcpu=0.70v |
| PMU_VF_TABLE_REG1         | 0x0084 | CPU speed max if the vddcpu=0.75v |
| PMU_VF_TABLE_REG2         | 0x0088 | CPU speed max if the vddcpu=0.80v |
| PMU_VF_TABLE_REG3         | 0x008C | CPU speed max if the vddcpu=0.85v |
| PMU_VF_TABLE_REG4         | 0x0090 | CPU speed max if the vddcpu=0.90v |
| PMU_VF_TABLE_REG5         | 0x0094 | CPU speed max if the vddcpu=0.95v |
| PMU_VF_TABLE_REG6         | 0x0098 | CPU speed max if the vddcpu=1.00v |
| PMU_VF_TABLE_REG7         | 0x009C | CPU speed max if the vddcpu=1.05v |
| PMU_VF_TABLE_REG8         | 0x00A0 | CPU speed max if the vddcpu=1.10v |

|                           |        |                                   |
|---------------------------|--------|-----------------------------------|
| PMU_VF_TABLE_REG9         | 0x00A4 | CPU speed max if the vddcpu=1.15v |
| PMU_VF_TABLE_REG10        | 0x00A8 | CPU speed max if the vddcpu=1.20v |
| PMU_VF_TABLE_REG11        | 0x00AC | CPU speed max if the vddcpu=1.25v |
| PMU_VF_TABLE_REG12        | 0x00B0 | CPU speed max if the vddcpu=1.30v |
| PMU_VF_TABLE_REG13        | 0x00B4 | CPU speed max if the vddcpu=1.35v |
| PMU_VF_TABLE_REG14        | 0x00B8 | CPU speed max if the vddcpu=1.40v |
| PMU_VF_TABLE_REG15        | 0x00BC | CPU speed max if the vddcpu=1.45v |
| PMU_VF_TABLE_REG16        | 0x00C0 | CPU speed max if the vddcpu=1.50v |
| PMU_VF_TABLE_REG17        | 0x00C4 | CPU speed max if the vddcpu=1.55v |
| PMU_VF_TABLE_REG18        | 0x00C8 | CPU speed max if the vddcpu=1.60v |
| PMU_VF_TABLE_VALID_REG    | 0x00CC | PMUVf Table Valid Control         |
| PMU_VF_TABLE_INDEX_REG    | 0x00D0 | PMU Vf Table Index                |
| PMU_VF_TABLE_RANGE_REG    | 0x00D4 | PMU Vf Table Range                |
| PMU_SPEED_FACTOR_REG0     | 0x00E0 | PMU Speed Factor Register 0       |
| PMU_SPEED_FACTOR_REG1     | 0x00E4 | PMU Speed Factor Register 1       |
| PMU_SPEED_FACTOR_REG2     | 0x00E8 | PMU Speed Factor Register 2       |
| CPU_IDLE_CNT_LOW_REG      | 0x00F0 | CPU Idle Counter Low              |
| CPU_IDLE_CNT_HIGH_REG     | 0x00F4 | CPU Idle Counter High             |
| CPU_IDLE_COUNTER_CTRL_REG | 0x00F8 | CPU Idle Counter Control          |
| CPU_IDLE_STATUS_REG       | 0x00FC | CPU Idle Status Register          |

## 5.3. PMU Register Description

### 5.3.1. PMU DVFS Control Register 0

| Offset: 0x00 |                |                 | Register Name: PMU_DVFS_CTRL_REG0                                                       |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                             |
| 31:18        | /              | /               | /                                                                                       |
| 17:16        | R/W            | 0x0             | DVFS_MODE_SEL.<br>DVFS Mode Select.<br>00: mode 0<br>01: mode 1<br>10: mode 2<br>11: /. |
| 15           | R/W            | 0x0             | AXI_DIV_AUTO_SWITCH.<br>AXICLK auto switch enable.<br>0: Disable, 1: Enable.            |
| 14:13        | /              | /               | /                                                                                       |
| 12           | R/W            | 0x0             | VOLT_CHANGE_MODE.<br>Voltage Change Mode<br>0: normal mode<br>1: maximum mode           |

|      |     |     |                                                                                      |
|------|-----|-----|--------------------------------------------------------------------------------------|
| 11:9 | /   | /   | /                                                                                    |
| 8    | R/W | 0x0 | CLK_CHANGE_SM_MODE.<br>Clock Change Smooth Mode<br>0: Divide mode<br>1: Gating mode. |
| 7    | R/W | 0x0 | SM_EN.<br>Smooth enable.<br>0: Disable, 1: Enable.                                   |
| 6    | R/W | 0x0 | CLK_SWTH_EN.<br>Clock switch enable.<br>0: Disable, 1: Enable.                       |
| 5    | R/W | 0x0 | VOLT_CHANGE_EN.<br>Voltage change enable.<br>0: Disable, 1: Enable.                  |
| 4    | R/W | 0x0 | SPD_DET_EN.<br>Speed detect enable.<br>0: Disable, 1: Enable.                        |
| 3:1  | /   | /   | /                                                                                    |
| 0    | R/W | 0x0 | DVFS_EN.<br>PMU DVFS Enable.<br>0: Disable<br>1: Enable.                             |

### 5.3.2. PMU DVFS Control Register 1(Default : 0x00001010)

| Offset: 0x04 |                |                 | Register Name: PMU_DVFS_CTRL_REG1      |
|--------------|----------------|-----------------|----------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                            |
| 31:24        | /              | /               | /                                      |
| 23:8         | R/W            | 0x10            | PLL_STAB_TIME<br>PLL stable time.      |
| 7:0          | R/W            | 0x10            | SM_INTV_VALUE<br>Smooth interval value |

### 5.3.3. PMU DVFS Control Register 2

| Offset: 0x0C |                |                 | Register Name: PMU_DVFS_CTRL_REG2                                                                                                                                                                   |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                         |
| 31:1         | /              | /               | /                                                                                                                                                                                                   |
| 0            | R/W            | 0x0             | VOLT_SET_EN.<br>Voltage Set Enable.<br>It will be auto cleared after the voltage setting command is sent successfully.<br>Set this bit to 1 will start the voltage setting (set the CPUVDD register |

|  |  |  |                                                          |
|--|--|--|----------------------------------------------------------|
|  |  |  | value to the external PMU IC through the TWI interface). |
|--|--|--|----------------------------------------------------------|

Note: This bit can not be set to one if the VoltageChangeEnable bit in the DVFS Ctrl register 0 is set to 1.

#### 5.3.4. PMU AXI Clock Range Register0

| Offset: 0x20 |                |                 | Register Name: PMU_AXI_AUTO_SWT_REG0 |
|--------------|----------------|-----------------|--------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                          |
| 31:27        | /              | /               | /                                    |
| 26:16        | R/W            | 0x0             | AXI_CLK_LEVEL1<br>AXICLK level 1     |
| 15:11        | /              | /               | /                                    |
| 10:0         | R/W            | 0x0             | AXI_CLK_LEVEL0<br>AXICLK level 0     |

#### 5.3.5. PMU AXI Clock Range Register1

| Offset: 0x24 |                |                 | Register Name: PMU_AXI_AUTO_SWT_REG1 |
|--------------|----------------|-----------------|--------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                          |
| 31:27        | /              | /               | /                                    |
| 26:16        | R/W            | 0x0             | AXI_CLK_LEVEL3<br>AXICLK level 3     |
| 15:11        | /              | /               | /                                    |
| 10:0         | R/W            | 0x0             | AXI_CLK_LEVEL2<br>AXICLK level 2     |

#### 5.3.6. PMU DVFS Control Register 3

| Offset: 0x18 |                |                 | Register Name: PMU_DVFS_CTRL_REG3 |
|--------------|----------------|-----------------|-----------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                       |
| 31:0         | /              | /               | /                                 |

#### 5.3.7. PMU DVFS TimeOut Control Register(Default : 0x00000027)

| Offset: 0x1C |                |                 | Register Name: PMU_DVFS_TIMEOUT_CTRL_REG                                                                               |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                            |
| 31:6         | /              | /               |                                                                                                                        |
| 5:0          | R/W            | 0x27            | DVFS_TIMEOUT.<br>DVFS operate on TWI timeout cycles in TWI peripheral clock.<br>0: 1 cycle<br>.....<br>0x27: 40 cycles |

|  |  |  |                          |
|--|--|--|--------------------------|
|  |  |  | .....<br>0x3F: 64 cycles |
|--|--|--|--------------------------|

### 5.3.8. PMU IRQ En Register

| Offset: 0x40 |                |                 | Register Name: PMU_IRQ_EN_REG                                                                            |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                              |
| 31:13        | /              | /               | /                                                                                                        |
| 12           | R/W            | 0x0             | VOLT_DET_ERR_IRQ_EN.<br>Voltage Detect Error IRQ Enable.<br>0: Disable<br>1: Enable.                     |
| 11           | R/W            | 0x0             | DVFS_CLK_SWTH_ERR_IRQ_EN.<br>DVFS Clock Switch Operation Error IRQ Enable.<br>0: Disable<br>1: Enable.   |
| 10           | R/W            | 0x0             | DVFS_VOLT_CHANGE_ERR_EN.<br>DVFS Voltage Change Error Enable.<br>0: Disable,<br>1: Enable.               |
| 9            | R/W            | 0x0             | DVFS_SPD_DET_ERR_IRQ_EN.<br>DVFS Speed Detect Error IRQ Enable.<br>0: Disable<br>1: Enable.              |
| 8:5          | /              | /               | /                                                                                                        |
| 4            | R/W            | 0x0             | VOLT_DET_FIN_IRQ_EN.<br>Voltage Detect Finished IRQ Enable.<br>0: Disable<br>1: Enable.                  |
| 3            | R/W            | 0x0             | DVFS_CLK_SWT_FIN_IRQ_EN.<br>DVFS Clock Switch Operation Finished IRQ Enable.<br>0: Disable<br>1: Enable. |
| 2            | R/W            | 0x0             | DVFS_VOLT_CHANGE_FIN_EN.<br>DVFS Voltage Change Finished Enable.<br>0: Disable,<br>1: Enable.            |
| 1            | R/W            | 0x0             | DVFS_SPD_DET_FIN_IRQ_EN.<br>DVFS Speed Detect Finished IRQ Enable.<br>0: Disable,<br>1: Enable.          |
| 0            | R/W            | 0x0             | DVFS_FIN_IRQ_EN.<br>DVFS Finished IRQ Enable.                                                            |

|  |  |  |                          |
|--|--|--|--------------------------|
|  |  |  | 0: Disable<br>1: Enable. |
|--|--|--|--------------------------|

### 5.3.9. PMU IRQ Status Register

| Offset: 0x44 |                |                 | Register Name: PMU_IRQ_STATUS_REG                                                                                                                  |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                        |
| 31:13        | /              | /               | /                                                                                                                                                  |
| 12           | R/W            | 0x0             | VOLT_DET_ERR_IRQ_PEND.<br>Voltage Detect Error IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it...                   |
| 11           | R/W            | 0x0             | DVFS_CLK_SWT_ERR_IRQ_PEND.<br>DVFS Clock Switch Operation Error IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.    |
| 10           | R/W            | 0x0             | DVFS_VOLT_CHANGE_ERR_PEND.<br>DVFS Voltage Change Error Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.                |
| 9            | R/W            | 0x0             | DVFS_SPD_DET_ERR_IRQ_PEND.<br>DVFS Speed Detect Error IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.              |
| 8:5          | /              | /               | /                                                                                                                                                  |
| 4            | R/W            | 0x0             | VOLT_DET_FIN_IRQ_PEND.<br>Voltage Detect Finished IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.                  |
| 3            | R/W            | 0x0             | DVFS_CLK_SWT_FIN_IRQ_PEND.<br>DVFS Clock Switch Operation Finished IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it. |
| 2            | R/W            | 0x0             | DVFS_VOLT_CHANGE_FIN_PEND.<br>DVFS Voltage Change Finished Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.             |
| 1            | R/W            | 0x0             | DVFS_SPD_DET_FIN_IRQ_PEND.<br>DVFS Speed Detect Finished IRQ Pending.<br>0: No effect,<br>1: Pending. Set one to this bit will clear it.           |
| 0            | R/W            | 0x0             | DVFS_FIN_IRQ_PEND.<br>DVFS Finished IRQ Pending.                                                                                                   |

|  |  |  |                                                                 |
|--|--|--|-----------------------------------------------------------------|
|  |  |  | 0: No effect,<br>1: Pending. Set one to this bit will clear it. |
|--|--|--|-----------------------------------------------------------------|

### 5.3.10. PMU Status Register

| Offset: 0x48 |                |                 | Register Name: PMU_STATUS_REG                                |
|--------------|----------------|-----------------|--------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31:1         | /              | /               | /                                                            |
| 0            | R/W            | 0x0             | DVFS_BUSY.<br>DVFS Busy.<br>0: no effect<br>1: DVFS is busy. |

### 5.3.11. PMU CPUVDD DCDC Control Register Address(Default : 0x00000023)

| Offset: 0x4C |                |                 | Register Name: PMU_CPUVDD_CTRL_REG_ADDR                            |
|--------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 31:8         | /              | /               | /.                                                                 |
| 7:0          | R/W            | 0x23            | CPUVDD_CTRL_REG_ADDR.<br>PMU CPUVDD DCDC Control Register address. |

### 5.3.12. PMU TWI Address(Default : 0x00000068)

| Offset: 0x50 |                |                 | Register Name: PMU_TWI_ADDR_REG       |
|--------------|----------------|-----------------|---------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                           |
| 31:8         | /              | /               | /.                                    |
| 7:0          | R/W            | 0x68            | PMU_TWI_ADDR.<br>PMU TWI address set. |

### 5.3.13. PMU CPUVDD Value(Default : 0x00000016)

| Offset: 0x54 |                |                 | Register Name: PMU_CPUVDD_VALUE_REG                                                                                                         |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                 |
| 31:8         | /              | /               | /.                                                                                                                                          |
| 7:0          | R/W            | 0x16            | CPUVDD_DEFAULT.<br>PMU CPUVDD Default Value<br>0x00 = 0.70v<br>0x02 = 0.75v<br>0x04 = 0.80v<br>0x06 = 0.85v<br>0x08 = 0.90v<br>0x0A = 0.95v |

|  |  |  |                                                                                                                                                                                                              |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0x0C = 1.00v<br>0x0E = 1.05v<br>0x10 = 1.10v<br>0x12 = 1.15v<br>0x14 = 1.20v<br>0x16 = 1.25v<br>0x18 = 1.30v<br>0x1A = 1.35v<br>0x1C = 1.40v<br>0x1E = 1.45v<br>0x20 = 1.50v<br>0x22 = 1.55v<br>0x24 = 1.60v |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Note: This register can be modified by PMU DVFS.

### 5.3.14. PMU CPUVDD Voltage Ramp Control in DVM

| Offset: 0x58 |                |                 | Register Name: PMU_CPUVDD_RAMP_CTRL_REG                                                     |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                 |
| 31:1         | /              | /               | /.                                                                                          |
| 0            | R/W            | 0x0             | CPUVDD_VOLT_RAMP_CTRL.<br>CPUvdd voltage ramp control in DVM<br>0 = 15.625us<br>1 = 31.25us |

Note: If the cpuvdd voltage ramp control in the external PMU is changed by the CPU, the CPU should also modify this to be the same in the PMU.

### 5.3.15. PMU 32KHz CPUVDD Minimum Value(Default : 0x0000000C)

| Offset: 0x5C |                |                 | Register Name: PMU_32KHZ_CPUVDD_MIN_REG                                                                                                                                                             |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                         |
| 31:8         | /              | /               | /.                                                                                                                                                                                                  |
| 7:0          | R/W            | 0xc             | CPUVDD_32KHZ_MIN_VALUE.<br>PMU CPUVDD Default Value<br>0x00 = 0.70v<br>0x02 = 0.75v<br>0x04 = 0.80v<br>0x06 = 0.85v<br>0x08 = 0.90v<br>0x0A = 0.95v<br>0x0C = 1.00v<br>0x0E = 1.05v<br>0x10 = 1.10v |

|  |  |  |                                                                                                                                                              |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 0x12 = 1.15v<br>0x14 = 1.20v<br>0x16 = 1.25v<br>0x18 = 1.30v<br>0x1A = 1.35v<br>0x1C = 1.40v<br>0x1E = 1.45v<br>0x20 = 1.50v<br>0x22 = 1.55v<br>0x24 = 1.60v |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 5.3.16. PMU VF Table Register 0

| Offset: 0x80 |                |                 | Register Name: PMU_VF_TABLE_REG0                                                                                                         |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                              |
| 31:11        | /              | /               | /                                                                                                                                        |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_070.<br>CPU max frequency if cpuvdd=0.7v (unit: MHz)<br>This register can only be written if the DVFS function is disabled. |

### 5.3.17. PMU VF Table Register 1

| Offset: 0x84 |                |                 | Register Name: PMU_VF_TABLE_REG1                                                                                                           |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /                                                                                                                                          |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_075.<br>CPU max frequency if cpuvdd=0.75v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.18. PMU VF Table Register 2

| Offset: 0x88 |                |                 | Register Name: PMU_VF_TABLE_REG2                                                                                                          |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_080.<br>CPU max frequency if cpuvdd=0.8v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.19. PMU VF Table Register 3

| Offset: 0x8C |                |                 | Register Name: PMU_VF_TABLE_REG3 |
|--------------|----------------|-----------------|----------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                      |
| 31:11        | /              | /               | /                                |

|      |     |   |                                                                                                                                            |
|------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------|
| 10:0 | R/W | x | CPU_MAX_FREQ_085.<br>CPU max frequency if cpuvdd=0.85v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |
|------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------|

### 5.3.20. PMU VF Table Register 4

| Offset: 0x90 |                |                 | Register Name: PMU_VF_TABLE_REG4                                                                                                          |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_090.<br>CPU max frequency if vddcpu=0.9v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.21. PMU VF Table Register 5

| Offset: 0x94 |                |                 | Register Name: PMU_VF_TABLE_REG5                                                                                                           |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /                                                                                                                                          |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_095.<br>CPU max frequency if cpuvdd=0.95v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.22. PMU VF Table Register 6

| Offset: 0x98 |                |                 | Register Name: PMU_VF_TABLE_REG6                                                                                                          |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_100.<br>CPU max frequency if cpuvdd=1.0v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.23. PMU VF Table Register 7

| Offset: 0x9C |                |                 | Register Name: PMU_VF_TABLE_REG7                                                                                                           |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /                                                                                                                                          |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_105.<br>CPU max frequency if cpuvdd=1.05v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.24. PMU VF Table Register 8

|              |                                  |
|--------------|----------------------------------|
| Offset: 0xA0 | Register Name: PMU_VF_TABLE_REG8 |
|--------------|----------------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
|-------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 31:11 | /              | /               | /                                                                                                                                         |
| 10:0  | R/W            | x               | CPU_MAX_FREQ_110.<br>CPU max frequency if cpuvdd=1.1v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.25. PMU VF Table Register 9

| Offset: 0xA4 |                |                 | Register Name: PMU_VF_TABLE_REG9                                                                                                           |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /                                                                                                                                          |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_115.<br>CPU max frequency if cpuvdd=1.15v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.26. PMU VF Table Register 10

| Offset: 0xA8 |                |                 | Register Name: PMU_VF_TABLE_REG10                                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_120.<br>CPU max frequency if cpuvdd=1.2v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.27. PMU VF Table Register 11

| Offset: 0xAC |                |                 | Register Name: PMU_VF_TABLE_REG11                                                                                                          |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /                                                                                                                                          |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_125.<br>CPU max frequency if cpuvdd=1.25v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.28. PMU VF Table Register 12

| Offset: 0xB0 |                |                 | Register Name: PMU_VF_TABLE_REG12                                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_130.<br>CPU max frequency if cpuvdd=1.3v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.29. PMU VF Table Register 13

| Offset: 0xB4 |                |                 | Register Name: PMU_VF_TABLE_REG13                                                                                                          |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /.                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_135.<br>CPU max frequency if cpuvdd=1.35v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.30. PMU VF Table Register 14

| Offset: 0xB8 |                |                 | Register Name: PMU_VF_TABLE_REG14                                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /.                                                                                                                                        |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_140.<br>CPU max frequency if cpuvdd=1.4v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.31. PMU VF Table Register 15

| Offset: 0xBC |                |                 | Register Name: PMU_VF_TABLE_REG15                                                                                                          |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:11        | /              | /               | /.                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_145.<br>CPU max frequency if cpuvdd=1.45v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.32. PMU VF Table Register 16

| Offset: 0xC0 |                |                 | Register Name: PMU_VF_TABLE_REG16                                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_150.<br>CPU max frequency if cpuvdd=1.5v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.33. PMU VF Table Register 17

| Offset: 0xC4 |                |                 | Register Name: PMU_VF_TABLE_REG17 |
|--------------|----------------|-----------------|-----------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                       |
| 31:11        | /              | /               | /                                 |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_155.                 |

|  |  |  |                                                                                                                       |
|--|--|--|-----------------------------------------------------------------------------------------------------------------------|
|  |  |  | CPU max frequency if cpuvdd=1.55v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |
|--|--|--|-----------------------------------------------------------------------------------------------------------------------|

### 5.3.34. PMU VF Table Register 18

| Offset: 0xC8 |                |                 | Register Name: PMU_VF_TABLE_REG18                                                                                                         |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                               |
| 31:11        | /              | /               | /                                                                                                                                         |
| 10:0         | R/W            | x               | CPU_MAX_FREQ_160.<br>CPU max frequency if cpuvdd=1.6v (unit: MHz).<br>This register can only be written if the DVFS function is disabled. |

### 5.3.35. PMU VF Table Valid Register

| Offset: 0xCC |                |                 | Register Name: PMU_VF_TABLE_VALID_REG                                              |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                        |
| 31:16        | R/W            | 0x0             | /                                                                                  |
| 15:6         | /              | /               | /                                                                                  |
| 5            | R/W            | 0x1             | VF_TABLE_18_VALID.<br>PMU V-F Table Register 18 valid.<br>0: valid,<br>1: invalid. |
| 4            | R/W            | 0x1             | VF_TABLE_17_VALID.<br>PMU V-F Table Register 17 valid.<br>0: valid<br>1: invalid   |
| 3            | R/W            | 0x1             | VF_TABLE_16_VALID.<br>PMU V-F Table Register 16 valid.<br>0: valid<br>1: invalid   |
| 2            | R/W            | 0x1             | VF_TABLE_15_VALID.<br>PMU V-F Table Register 15 valid.<br>0: valid<br>1: invalid   |
| 1            | R/W            | 0x0             | VF_TABLE_14_VALID.<br>PMU V-F Table Register 14 valid.<br>0: valid<br>1: invalid   |
| 0            | R/W            | 0x0             | VF_TABLE_13_VALID.<br>PMU V-F Table Register 13 valid.<br>0: valid<br>1: invalid   |

### 5.3.36. PMU VF Table Index Register

| Offset: 0xD0 |                |                 | Register Name: PMU_VF_TABLE_INDEX_REG                          |
|--------------|----------------|-----------------|----------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                    |
| 31:2         | /              | /               | /                                                              |
| 1:0          | R/W            | 0x0             | VF_TABLE_IDX.<br>PMU V-F Table Index.<br>00:<br>01<br>10<br>11 |

### 5.3.37. PMU VF Table Range Register

| Offset: 0xD4 |                |                 | Register Name: PMU_VF_TABLE_RANGE_REG    |
|--------------|----------------|-----------------|------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                              |
| 31:24        | /              | /               | /                                        |
| 23:16        | R/W            | 0x0             | VF_TABLE_RNG2.<br>PMU V-F Table Range 2. |
| 15:8         | R/W            | 0x0             | VF_TABLE_RNG1.<br>PMU V-F Table Range 1. |
| 7:0          | R/W            | 0x0             | VF_TABLE_RNG0.<br>PMU V-F Table Range 0. |

### 5.3.38. PMU Speed Factor Register 0

| Offset: 0xE0 |                |                 | Register Name: PMU_SPEED_FACTOR_REG0                                                                                                                          |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                   |
| 31           | R/W            | 0x0             | SPD_DET_EN.<br>Speed Detect Enable.<br>0: Disable,<br>1: Enable                                                                                               |
| 30           | R/W            | 0x0             | SPD_DET_MODE.<br>Speed Detect Mode.<br>0: single mode<br>1: continuous mode                                                                                   |
| 29:28        | R/W            | 0x0             | SPD_DET_SPDUP_FACTOR.<br>Speed Detect Speed Up Factor<br>Set these bits to non-zero value can speed up the scan operation<br>00: lowest<br>...<br>11: fastest |
| 27:17        | /              | /               | /                                                                                                                                                             |

|      |   |     |                                                                                                                         |
|------|---|-----|-------------------------------------------------------------------------------------------------------------------------|
| 16   | R | 0x0 | SPD_DET_SCN_FIN.<br>Speed Detect Scan Finished<br>0: no effect,<br>1: scan finished.                                    |
| 15:8 | R | 0x0 | SPD_DET_FACTOR1<br>Speed Detect Factor 1<br>This number indicates the delay length equivalent to input clock period x2  |
| 7:0  | R | 0x0 | SPD_DET_FACTOR0.<br>Speed Detect Factor 0<br>This number indicates the delay length equivalent to input clock period x1 |

### 5.3.39. PMU Speed Factor Register 1

| Offset: 0xE4 |                |                 | Register Name: PMU_SPEED_FACTOR_REG1                                                                                                                         |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                  |
| 31           | R/W            | 0x0             | SPD_DET_EN.<br>Speed Detect Enable.<br>0: Disable,<br>1: Enable                                                                                              |
| 30           | R/W            | 0x0             | SPD_DET_MODE.<br>Speed Detect Mode.<br>0: single mode<br>1: continuous mode                                                                                  |
| 29:28        | R/W            | 0x0             | SPD_DET_SPDUP_FACTOR<br>Speed Detect Speed Up Factor<br>Set these bits to non-zero value can speed up the scan operation<br>00: lowest<br>...<br>11: fastest |
| 27:17        | /              | /               | /                                                                                                                                                            |
| 16           | R              | 0x0             | SPD_DET_SCN_FIN<br>Speed Detect Scan Finished<br>0: no effect,<br>1: scan finished.                                                                          |
| 15:8         | R              | 0x0             | SPD_DET_FACTOR1<br>Speed Detect Factor 1<br>This number indicates the delay length equivalent to input clock period x2                                       |
| 7:0          | R              | 0x0             | SPD_DET_FACTOR0.<br>Speed Detect Factor 0<br>This number indicates the delay length equivalent to input clock period x1                                      |

|  |  |  |    |
|--|--|--|----|
|  |  |  | x1 |
|--|--|--|----|

### 5.3.40. PMU Speed Factor Register 2

| Offset: 0xE8 |                |                 | Register Name: PMU_SPEED_FACTOR_REG2                                                                                                                         |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                  |
| 31           | R/W            | 0x0             | SPD_DET_EN.<br>Speed Detect Enable.<br>0: Disable,<br>1: Enable                                                                                              |
| 30           | R/W            | 0x0             | SPD_DET_MODE.<br>Speed Detect Mode.<br>0: single mode<br>1: continuous mode                                                                                  |
| 29:28        | R/W            | 0x0             | SPD_DET_SPDUP_FACTOR<br>Speed Detect Speed Up Factor<br>Set these bits to non-zero value can speed up the scan operation<br>00: lowest<br>...<br>11: fastest |
| 27:17        | /              | /               | /                                                                                                                                                            |
| 16           | R              | 0x0             | SPD_DET_SCN_FIN<br>Speed Detect Scan Finished<br>0: no effect,<br>1: scan finished.                                                                          |
| 15:8         | R              | 0x0             | SPD_DET_FACTOR1.<br>Speed Detect Factor 1<br>This number indicates the delay length equivalent to input clock period<br>x2                                   |
| 7:0          | R              | 0x0             | SPD_DET_FACTOR0<br>Speed Detect Factor 0<br>This number indicates the delay length equivalent to input clock period<br>x1                                    |

### 5.3.41. CPU Idle Counter Low Register (Default: 0x00000000)

| Offset: 0XF0 |                |                 | Register Name: CPU_IDLE_CNT_LOW_REG                                                                                                                                                                                                     |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                             |
| 31:0         | R/W            | 0x0             | CPU_IDLE_CNT_LO<br>CPU Idle Counter [31:0].<br>This counter clock source is 24MHz. If CPU is in idle state, the counter<br>will count up in the clock of 24MHz.<br>Any write to this register will clear this register and the CPU idle |

|  |  |  |                        |
|--|--|--|------------------------|
|  |  |  | counter high register. |
|--|--|--|------------------------|

### 5.3.42. CPU Idle Counter High Register (Default: 0x00000000)

| Offset: 0xF4 |                |                 | Register Name: CPU_IDLE_CNT_HIGH_REG                                                                                                        |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                 |
| 31:0         | R/W            | 0x0             | CPU_IDLE_CNT_HI.<br>CPU Idle Counter [63:32].<br>Any write to this register will clear this register and the CPU idle counter low register. |

### 5.3.43. CPU Idle Control Register (Default: 0x00000000)

| Offset: 0xF8 |                |                 | Register Name: CPU_IDLE_COUNTER_CTRL_REG                                                                                                                                                                                                                                                                                                                 |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                              |
| 31:8         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                        |
| 7            | R/W            | 0x0             | CPU_IDLE_AUTO_SWTH_EN.<br>CPU idle enter/exit, clk auto switch enable.<br>0: disable, 1: enable.<br>If the CPU enter the idle mode and this bit is set, the ccu will auto switch the CPU clock divide ratio to /8.<br>If the CPU exit the idle mode and this bit is set, the ccu will auto switch the CPU clock divide ratio from /8 to /1 with 4 steps. |
| 6:3          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                        |
| 2            | R/W            | 0x0             | CPU_IDLE_CNT_EN.<br>CPU idle counter enable.<br>0: disable<br>1: enable.                                                                                                                                                                                                                                                                                 |
| 1            | R/W            | 0x0             | CPU_IDLE_RL_EN.<br>CPU idle Counter Read Latch Enable.<br>0: no effect, 1: to latch the idle Counter to the Low/Hi registers and it will change to zero after the registers are latched.                                                                                                                                                                 |
| 0            | R/W            | 0x0             | CPU_IDLE_CNT_CLR_EN.<br>CPU idle Counter Clear Enable.<br>0: no effect, 1: to clear the idle Counter Low/Hi registers and it will change to zero after the registers are cleared.                                                                                                                                                                        |

### 5.3.44. CPU Idle Status Register (Default: 0x00000000)

| Offset: 0xFC |                |                 | Register Name: CPU_IDLE_STATUS_REG |
|--------------|----------------|-----------------|------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                        |
| 31:1         | /              | /               | /                                  |
| 0            | R/W            | 0x0             | CPU_IDLE_STA.                      |

|  |  |  |                                                                                                                |
|--|--|--|----------------------------------------------------------------------------------------------------------------|
|  |  |  | CPU idle exit finished pending.<br>0: no effect,<br>1: idle exit finished.<br>Set 1 to this bit will clear it. |
|--|--|--|----------------------------------------------------------------------------------------------------------------|

## 6. Clock Control Module (CCM)

### 6.1. Overview

The Clock Control Module (CCM) is made up of 7 PLLs, a Main Oscillator and an on-chip RC Oscillator. The 24-MHz crystal is mandatory and to generate input clock source for PLLs and main digital blocks.

In order to provide high performance, low-power consumption and user-friendly interfaces, the chip includes several clock domains: CPU clock, AHB clock, APB clock and special clock. See details in the following table.

| <b>CLK Domain</b> | <b>Module</b>        | <b>Speed Range</b>    | <b>Description</b>               |
|-------------------|----------------------|-----------------------|----------------------------------|
| OSC24M            | Most Clock Generator | 24MHz                 | Root clock for most of the chip  |
| RC_OSC            | Timer,key            | 32KHz                 | Source for the timer             |
| CPU32_clk         | CPU32                | 2K~1200M              | Divided from CPU32_clk or OSC24M |
| AHB_clk           | AHB Devices          | 8K~276M               | Divided from CPU32_clk           |
| APB_clk           | Peripheral           | 0.5K~138M             | Divided from AHB_clk             |
| SDRAM_clk         | SDRAM                | 0~400MHz              | Sourced from the PLL             |
| USB_clk           | USB                  | 480MHz                | Sourced from the PLL             |
| Audio_clk         | A/D,D/A              | 24.576MHz /22.5792MHz | Sourced from the PLL             |

## 6.2. Clock Tree Diagram



Figure 6-1 Clock Generation from PLL Outputs



Figure 6-2 Bus Clock Generation Part 1



Figure6-3 Bus Clock Generation Part 2

### 6.3. CCM Register List

| Module Name | Base Address |
|-------------|--------------|
| CCM         | 0x01C20000   |

| Register Name        | Offset | Description                    |
|----------------------|--------|--------------------------------|
| PLL1_CFG_REG         | 0x0000 | PLL1 Control                   |
| PLL1_TUN_REG         | 0x0004 | PLL1 Tuning                    |
| PLL2_CFG_REG         | 0x0008 | PLL2 Control                   |
| PLL2_TUN_REG         | 0x000C | PLL2 Tuning                    |
| PLL3_CFG_REG         | 0x0010 | PLL3 Control                   |
| /                    | 0x0014 | /                              |
| PLL4_CFG_REG         | 0x0018 | PLL4 Control                   |
| /                    | 0x001C | /                              |
| PLL5_CFG_REG         | 0x0020 | PLL5 Control                   |
| PLL5_TUN_REG         | 0x0024 | PLL5 Tuning                    |
| PLL6_CFG_REG         | 0x0028 | PLL6 Control                   |
| /                    | 0x002C | PLL6 Tuning                    |
| PLL7_CFG_REG         | 0x0030 | /                              |
| /                    | 0x0034 | /                              |
| PLL1_TUN2_REG        | 0x0038 | PLL1 Tuning2                   |
| PLL5_TUN2_REG        | 0x003C | PLL5 Tuning2                   |
| /                    | 0x004C | /                              |
| OSC24M_CFG_REG       | 0x0050 | OSC24M control                 |
| CPU_AHB_APB0_CFG_REG | 0x0054 | CPU, AHB And APB0 Divide Ratio |
| APB1_CLK_DIV_REG     | 0x0058 | APB1 Clock Divider             |
| AXI_GATING_REG       | 0x005C | AXI Module Clock Gating        |
| AHB_GATING_REG0      | 0x0060 | AHB Module Clock Gating 0      |
| AHB_GATING_REG1      | 0x0064 | AHB Module Clock Gating 1      |
| APB0_GATING_REG      | 0x0068 | APB0 Module Clock Gating       |
| APB1_GATING_REG      | 0x006C | APB1 Module Clock Gating       |
| NAND_SCLK_CFG_REG    | 0x0080 | Nand Flash Clock               |
| /                    | 0x0084 | /                              |
| SD0_SCLK_CFG_REG     | 0x0088 | SD0 Clock                      |
| SD1_SCLK_CFG_REG     | 0x008C | SD1 Clock                      |
| SD2_SCLK_CFG_REG     | 0x0090 | SD2 Clock                      |
| /                    | 0x0094 | /                              |
| TS_SCLK_CFG_REG      | 0x0098 | Transport Stream Clock         |
| SS_SCLK_CFG_REG      | 0x009C | Security System Clock          |
| SPI 0_SCLK_CFG_REG   | 0x00A0 | SPI0 Clock                     |
| SPI 1_SCLK_CFG_REG   | 0x00A4 | SPI1 Clock                     |
| SPI 2_SCLK_CFG_REG   | 0x00A8 | SPI2 Clock                     |

|                          |        |                                  |
|--------------------------|--------|----------------------------------|
| /                        | 0x00AC | /                                |
| IR_SCLK_CFG_REG          | 0x00B0 | IR Clock                         |
| /                        | 0x00B4 | /                                |
| IIS_SCLK_CFG_REG         | 0x00B8 | IIS Clock                        |
| /                        | 0x00BC | /                                |
| /                        | 0x00C0 | /                                |
| /                        | 0x00C4 | /                                |
| /                        | 0x00C8 | /                                |
| /                        | 0x00CC | /                                |
| GPS_CFG_REG              | 0x00D0 | GPS Clock                        |
| /                        | 0x00D4 | /                                |
| DRAM_SCLK_CFG_REG        | 0x0100 | DRAM Clock                       |
| BE_CFG_REG               | 0x0104 | Display Engine Backend Clock     |
| /                        | 0x0108 |                                  |
| FE_CFG_REG               | 0x010C | Display Engine Front End Clock   |
| /                        | 0x0110 | /                                |
| /                        | 0x0114 | /                                |
| LCD_CH0_TVE_CFG_REG      | 0x0118 |                                  |
| /                        | 0x011C | /                                |
| /                        | 0x0120 | /                                |
| /                        | 0x0124 | /                                |
| /                        | 0x0128 | /                                |
| LCD_CH1_CFG_REG          | 0x012C | LCD Channel1 Clock               |
| /                        | 0x0130 | /                                |
| CSI_CFG_REG              | 0x0134 | CSI Clock                        |
| /                        | 0x0138 | /                                |
| VE_CFG_REG               | 0x013C | Video Engine Clock               |
| AUDIO_CODEC_SCLK_CFG_REG | 0x0140 | Audio Codec Gating Special Clock |
| AVS_SCLK_CFG_REG         | 0x0144 | AVS Gating Special Clock         |
| /                        | 0x0148 | /                                |
| /                        | 0x014C | /                                |
| HDMI_SCLK_CFG_REG        | 0x0150 | HDMI Gating Special Clock        |
| MALI_CLOCK_CFG_REG       | 0x0154 | Mali400 Gating Special Clock     |
| /                        | 0x0158 | /                                |
| MBUS_SCLK_CFG_REG        | 0x015C | MBUS Gating Clock                |
| IEP_SCLK_CFG_REG         | 0x0160 | IEP Gating Clock                 |

## 6.4. CCM Register Description

### 6.4.1. PLL1-Core (Default: 0x21005000)

| Offset: 0x00 |        | Register Name: PLL1_CFG_REG |             |
|--------------|--------|-----------------------------|-------------|
| Bit          | Read/W | Default/                    | Description |

|       | rite | Hex  |                                                                                                                                                                                                                                                    |
|-------|------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W  | 0x0  | PLL1_Enable.<br>0: Disable, 1: Enable.<br>The PLL1 output= (24MHz*N*K)/ (M*P).<br>The PLL1 output is for the CORECLK.<br>Note: the output 24MHz*N*K clock must be in the range of 240MHz~2GHz if the bypass is disabled.<br>Its default is 384MHz. |
| 30:18 | /    | /    | /                                                                                                                                                                                                                                                  |
| 17:16 | R/W  | 0x0  | PLL1_OUT_EXT_DIVP.<br>PLL1 Output external divider P.<br>The range is 1/2/4/8.                                                                                                                                                                     |
| 15:13 | /    | /    | /.                                                                                                                                                                                                                                                 |
| 12:8  | R/W  | 0x10 | PLL1_FACTOR_N<br>PLL1 Factor N.<br>Factor=0, N=0;<br>Factor=1, N=1;<br>Factor=2, N=2<br>.....<br>Factor=31, N=31                                                                                                                                   |
| 7:6   | /    | /    | /                                                                                                                                                                                                                                                  |
| 5:4   | R/W  | 0x0  | PLL1_FACTOR_K.<br>PLL1 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4.                                                                                                                                                                       |
| 3     | R/W  | 0x0  | /                                                                                                                                                                                                                                                  |
| 2     | R/W  | 0x0  | /                                                                                                                                                                                                                                                  |
| 1:0   | R/W  | 0x0  | PLL1_FACTOR_M.<br>PLL1 Factor M. (M=Factor + 1 )<br>The range is from 1 to 4.                                                                                                                                                                      |

#### 6.4.2. PLL1-Tuning (Default: 0x0A101000)

| Offset: 0x04 |                | Register Name: PLL1_TUN_REG |             |
|--------------|----------------|-----------------------------|-------------|
| Bit          | Read/W<br>rite | Default/<br>Hex             | Description |
| 31:28        | /              | /                           | /           |
| 27           | R/W            | 0x1                         | /           |
| 26           | R/W            | 0x0                         | /           |
| 25:23        | R/W            | 0x4                         | /           |
| 22:16        | R/W            | 0x10                        | /           |
| 15           | R/W            | 0x0                         | /           |
| 14:8         | R/W            | 0x10                        | /           |
| 7            | R/W            | 0x0                         | /           |

|     |   |     |   |
|-----|---|-----|---|
| 6:0 | R | 0x0 | / |
|-----|---|-----|---|

#### 6.4.3. PLL2-Audio (Default: 0x08100010)

| Offset: 0x08 |                |                 | Register Name: PLL2_CFG_REG                                                                                                                                                                                                                                                       |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                       |
| 31           | R/W            | 0x0             | PLL2_Enable.<br>0: Disable, 1: Enable.<br>The PLL2 is for Audio.<br>PLL2 Output = 24MHz*N/PLL2_PRE_DIV/PLL2_POST_DIV.<br>1X = 48*N/PreDiv/PostDiv/2(not 50% duty)<br>2X = 48*N/PreDiv/4( 8X/4 50% duty)<br>4X = 48*N/PreDiv/2( 8X/2 50% duty )<br>8X = 48*N/PreDiv( not 50% duty) |
| 30           | /              | /               | /                                                                                                                                                                                                                                                                                 |
| 29:26        | R/W            | 0x2             | PLL2_POST_DIV.<br>PLL2 post-divider [3:0].<br>0000: 0x1<br>.....<br>1111: 0x10                                                                                                                                                                                                    |
| 25:21        | R/W            | 0x0             | /                                                                                                                                                                                                                                                                                 |
| 20:16        | R/W            | 0x10            | /                                                                                                                                                                                                                                                                                 |
| 15           | /              | /               | /                                                                                                                                                                                                                                                                                 |
| 14:8         | R/W            | 0x0             | PLL2_Factor_N.<br>PLL2 Factor N.<br>Factor=0, N=1;<br>Factor=1, N=1;<br>.....<br>Factor=0x7F, N=0x7F;                                                                                                                                                                             |
| 7:5          | /              | /               | /                                                                                                                                                                                                                                                                                 |
| 4:0          | R/W            | 0x10            | PLL2_PRE_DIV.<br>PLL2 pre-divider [4:0].<br>00000: 0x1<br>.....<br>11111: 0x20                                                                                                                                                                                                    |

#### 6.4.4. PLL2-Tuning (Default: 0x00000000)

| Offset: 0x0C |                |                 | Register Name: PLL2_TUN_REG |
|--------------|----------------|-----------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                 |
| 31           | R/W            | 0x0             | /                           |
| 30:29        | R/W            | 0x0             | /                           |
| 28:20        | R/W            | 0x0             | /                           |

|       |     |     |   |
|-------|-----|-----|---|
| 19    | /   | /   | / |
| 18:17 | R/W | 0x0 | / |
| 16:0  | R/W | 0x0 | / |

#### 6.4.5. PLL3-Video (Default: 0x0010D063)

| Offset: 0x10 |                |                 | Register Name: PLL3_CFG_REG                                                                                                                                                                      |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                      |
| 31           | R/W            | 0x0             | PLL3_Enable.<br>0: Disable, 1: Enable.<br>In the integer mode, The PLL3 output=3MHz*M.<br>In the fractional mode, the PLL3 output is select by bit 14.<br>The PLL3 output range is 27MHz~381MHz. |
| 30:27        | /              | /               | /                                                                                                                                                                                                |
| 26:24        | R/W            | 0x0             | /                                                                                                                                                                                                |
| 23:21        | /              | /               | /                                                                                                                                                                                                |
| 20:16        | R/W            | 0x10            | /                                                                                                                                                                                                |
| 15           | R/W            | 0x1             | PLL3_MODE_SEL.<br>PLL3 mode select.<br>0: fractional mode, 1: integer mode.                                                                                                                      |
| 14           | R/W            | 0x1             | PLL3_FUNC_SET.<br>PLL3 fractional setting.<br>0: 270MHz, 1: 297MHz.                                                                                                                              |
| 13           | /              | /               | /                                                                                                                                                                                                |
| 12:8         | R/W            | 0x10            | /                                                                                                                                                                                                |
| 7            | /              | /               | /                                                                                                                                                                                                |
| 6:0          | R/W            | 0x63            | PLL3_FACTOR_M.<br>PLL3 Factor M.<br>The range is from 9 to 127.                                                                                                                                  |

#### 6.4.6. PLL4-VE (Default: 0x21081000)

| Offset: 0x18 |                |                 | Register Name: PLL4_CFG_REG                                                                                                                                                                                         |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                         |
| 31           | R/W            | 0x0             | PLL4_Enable.<br>0: Disable, 1: Enable.<br>The PLL4 output= (24MHz*N*K)/ (M*P).<br>The PLL4 output is for the VE.<br>Note: the output 24MHz*N*K clock must be in the range of 240MHz~2GHz if the bypass is disabled. |
| 30           | R/W            | 0x0             | PLL4_OUT_BYPASS_EN.<br>PLL4 Output Bypass Enable.                                                                                                                                                                   |

|       |     |      |                                                                                                                  |
|-------|-----|------|------------------------------------------------------------------------------------------------------------------|
|       |     |      | 0: Disable, 1: Enable.<br>If the bypass is enabled, the PLL4 output is 24MHz.                                    |
| 29:25 | R/W | 0x10 | /                                                                                                                |
| 24:20 | R/W | 0x10 | /                                                                                                                |
| 19    | R/W | 0x1  | /                                                                                                                |
| 18    | /   | /    | /.                                                                                                               |
| 17:16 | R/W | 0x0  | PLL4_OUT_EXT_DIV_P.<br>PLL4 Output external divider P.<br>The range is 1/2/4/8.                                  |
| 15:13 | /   | /    | /                                                                                                                |
| 12:8  | R/W | 0x10 | PLL4_FACTOR_N.<br>PLL4 Factor N.<br>Factor=0, N=0;<br>Factor=1, N=1;<br>Factor=2, N=2<br>.....<br>Factor=31,N=31 |
| 7:6   | /   | /    | /.                                                                                                               |
| 5:4   | R/W | 0x0  | PLL4_FACTOR_K.<br>PLL4 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4.                                     |
| 3:2   | /   | /    | /.                                                                                                               |
| 1:0   | R/W | 0x0  | PLL4_FACTOR_M.<br>PLL4 Factor M.(M = Factor + 1 )<br>The range is from 1 to 4.                                   |

#### 6.4.7. PLL5-DDR (Default: 0x11049280)

| Offset: 0x20 |                |                 | Register Name: PLL5_CFG_REG                                                                                                                                                                                                                                                   |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                   |
| 31           | R/W            | 0x0             | PLL5_Enable.<br>0: Disable, 1: Enable.<br>The PLL5 output for DDR = (24MHz*N*K)/M.<br>The PLL5 output for other module = (24MHz*N*K)/P.<br>The PLL5 output is for the DDR.<br>Note: the output 24MHz*N*K clock must be in the range of 240MHz~2GHz if the bypass is disabled. |
| 30           | R/W            | 0x0             | PLL5_OUT_BYPASS_EN.<br>PLL5 Output Bypass Enable.<br>0: Disable, 1: Enable.<br>If the bypass is enabled, the PLL6 output is 24MHz.                                                                                                                                            |
| 29           | R/W            | 0x0             | DDR_CLK_OUT_EN.<br>DDR clock output en.                                                                                                                                                                                                                                       |

|       |     |      |                                                                                                                  |
|-------|-----|------|------------------------------------------------------------------------------------------------------------------|
| 28:25 | R/W | 0x8  | /                                                                                                                |
| 24:20 | R/W | 0x10 | /                                                                                                                |
| 19    | R/W | 0x0  | /                                                                                                                |
| 18    | R/W | 0x1  | /                                                                                                                |
| 17:16 | R/W | 0x0  | PLL5_OUT_EXT_DIV_P.<br>PLL5 Output External Divider P.<br>The range is 1/2/4//8.                                 |
| 15:13 | R/W | 0x4  | /                                                                                                                |
| 12:8  | R/W | 0x12 | PLL5_FACTOR_N.<br>PLL5 Factor N.<br>Factor=0, N=0;<br>Factor=1, N=1;<br>Factor=2, N=2<br>.....<br>Factor=31,N=31 |
| 7     | R/W | 0x1  | LDO_EN.<br>LDO Enable.                                                                                           |
| 6     | /   | /    | /                                                                                                                |
| 5:4   | R/W | 0x0  | PLL5_FACTOR_K.<br>PLL5 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4.                                     |
| 3:2   | R/W | 0x0  | PLL5_FACTOR_M1.<br>PLL5 Factor M1.                                                                               |
| 1:0   | R/W | 0x0  | PLL5_FACTOR_M.<br>PLL5 Factor M.(M = Factor + 1 )<br>The range is from 1 to 4.                                   |

#### 6.4.8. PLL5-Tuning (Default: 0x14880000)

| Offset: 0x24 |                |                 | Register Name: PLL5_TUN_REG |
|--------------|----------------|-----------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                 |
| 31:0         | /              | /               | /                           |

#### 6.4.9. PLL6 (Default: 0x21009931)

| Offset: 0x28 |                |                 | Register Name: PLL6_CFG_REG                                                                                                                                                                     |
|--------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                     |
| 31           | R/W            | 0x0             | PLL6_Enable.<br>0: Disable, 1: Enable.<br>Output =(24MHz*N*K)/M/2<br>Note: the output 24MHz*N*K clock must be in the range of 240MHz~3GHz if the bypass is disabled.<br>Its default is 1200MHz. |

|       |     |      |                                                                                                                                |
|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------|
| 30    | R/W | 0x0  | PLL6_BYPASS_EN.<br>PLL6 Output Bypass Enable.<br>0: Disable, 1: Enable.<br>If the bypass is enabled, the PLL6 output is 24MHz. |
| 29:13 | /   | /    | /                                                                                                                              |
| 12:8  | R/W | 0x19 | PLL6_FACTOR_N.<br>PLL6 Factor N.<br>Factor=0, N=0;<br>Factor=1, N=1;<br>Factor=2, N=2;<br>.....<br>Factor=31, N=31             |
| 7:6   | /   | /    | PLL6 damping factor control [1:0].                                                                                             |
| 5:4   | /   | /    | PLL6_FACTOR_K.<br>PLL6 Factor K.(K=Factor + 1 )<br>The range is from 1 to 4.                                                   |
| 3:2   | /   | /    | /                                                                                                                              |
| 1:0   | R/W | 0x1  | PLL6_FACTOR_M.<br>PLL6 Factor M.(M = Factor + 1 )<br>The range is from 1 to 4.                                                 |

#### 6.4.10. PLL7 (Default: 0x0010D063)

| Offset: 0x30 |                |                 | Register Name: PLL7_CFG_REG                                                                                                                                                                      |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                      |
| 31           | R/W            | 0x0             | PLL7_Enable.<br>0: Disable, 1: Enable.<br>In the integer mode, The PLL7 output=3MHz*M.<br>In the fractional mode, the PLL7 output is select by bit 14.<br>The PLL7 output range is 27MHz~381MHz. |
| 30:16        | /              | /               | /                                                                                                                                                                                                |
| 15           | R/W            | 0x1             | PLL7_MODE_SEL.<br>PLL7 mode select.<br>0: fractional mode, 1: integer mode.                                                                                                                      |
| 14           | R/W            | 0x1             | PLL7_FRAC_SET.<br>PLL7 fractional setting.<br>0: 270MHz, 1: 297MHz.                                                                                                                              |
| 13:7         | /              | /               | /                                                                                                                                                                                                |
| 6:0          | R/W            | 0x63            | PLL7_FACTOR_M.<br>PLL7 Factor M.<br>The range is from 9 to 127.                                                                                                                                  |

#### **6.4.11. PLL1-Tuning2 (Default: 0x00000000)**

| Offset: 0x38 |                |                 | Register Name: PLL1_TUN2_REG                                                                     |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>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<br>11: awmode |
| 28:20        | R/W            | 0x0             | WAVE_STEP.<br>Wave step.                                                                         |
| 19           | /              | /               | /                                                                                                |
| 18:17        | R/W            | 0x0             | FREQ.<br>Frequency.<br>00: 31.5KHz<br>01: 32KHz<br>10: 32.5KHz<br>11: 33KHz                      |
| 16:0         | R/W            | 0x0             | WAVE_BOT.<br>Wave Bottom.                                                                        |

#### **6.4.12. PLL5-Tuning2 (Default: 0x00000000)**

| Offset: 0x3C |                |                 | Register Name: PLL5_TUN2_REG                                                                     |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>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<br>11: awmode |
| 28:20        | R/W            | 0x0             | WAVE_STEP.<br>Wave step.                                                                         |
| 19           | /              | /               | /                                                                                                |
| 18:17        | R/W            | 0x0             | FREQ.<br>Frequency.<br>00: 31.5KHz<br>01: 32KHz                                                  |

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

#### 6.4.13. OSC24M (Default: 0x00138013)

| Offset: 0x50 |                |                 | Register Name: OSC24M_CFG_REG                                  |
|--------------|----------------|-----------------|----------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                    |
| 31:24        | R/W            | 0x0             | /                                                              |
| 23:18        | /              | /               | /                                                              |
| 17           | R/W            | 0x1             | PLL_IN_PWR_SEL.<br>PLL Input Power Select.<br>0: 2.5v, 1: 3.3v |
| 16           | R/W            | 0x1             | LDO_EN.<br>LDO Enable.<br>0: Disable, 1: Enable.               |
| 15           | R/W            | 0x1             | PLL_BIAS_EN.<br>PLL Bias Enable.<br>0: disable,<br>1: enable.  |
| 14:2         | /              | /               | /                                                              |
| 1            | R/W            | 0x1             | OSC24M_GSM.<br>OSC24M GSM.                                     |
| 0            | R/W            | 0x1             | OSC24M_EN.<br>OSC24M Enable.<br>0: Disable, 1: Enable.         |

#### 6.4.14. CPU/AHB/APB0 Clock Ratio (Default: 0x00010010)

| Offset: 0x54 |                |                 | Register Name: CPU_AHB_APB0_CFG_REG                                                                                                                                                                                              |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                      |
| 31:18        | /              | /               | /                                                                                                                                                                                                                                |
| 17:16        | R/W            | 0x1             | CPU_CLK_SRC_SEL.<br>CPU Clock Source Select.<br>00: 32KHz OSC( Internal )<br>01: OSC24M<br>10: PLL1<br>11: 200MHz (source from the PLL6).<br>If the clock source is changed, at most to wait for 8 present running clock cycles. |
| 15:10        | /              | /               | /                                                                                                                                                                                                                                |
| 9:8          | R/W            | 0x0             | APB0_CLK_RATIO.                                                                                                                                                                                                                  |

|     |     |     |                                                                                                                         |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------|
|     |     |     | APB0 Clock divide ratio. APB0 clock source is AHB2 clock.<br>00: /2<br>01: /2<br>10: /4<br>11: /8                       |
| 7:6 | R/W | 0x0 | AHB_CLK_SRC_SEL.<br>00: AXI<br>01: CPUCLK<br>10: PLL6/2<br>11:                                                          |
| 5:4 | R/W | 0x1 | AHB_CLK_DIV_RATIO.<br>AHB Clock divide ratio.<br>AHB clock source is AXI Clock.<br>00: /1<br>01: /2<br>10: /4<br>11: /8 |
| 3:2 | /   | /   | /                                                                                                                       |
| 1:0 | R/W | 0x0 | AXI_CLK_DIV_RATIO.<br>AXI Clock divide ratio.<br>AXI Clock source is CPU clock.<br>00: /1<br>01: /2<br>10: /3<br>11: /4 |

#### 6.4.15. APB1 Clock Divide Ratio (Default: 0x00000000)

| Offset: 0x58 |                |                 | Register Name: APB1_CLK_DIV_REG                                                                                                                                                                                                                                        |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                                                                                                                                                                                                                            |
| 31:26        | /              | /               | /                                                                                                                                                                                                                                                                      |
| 25:24        | R/W            | 0x0             | APB1_CLK_SRC_SEL.<br>APB1 Clock Source Select<br>00: OSC24M<br>01: PLL6 (set to 1.2GHz)<br>10: 32KHz<br>11: /<br><br>This clock is used for some special module apbclk (TWI, UART, and SCR). Because these modules need special clock rate even if the apbclk changes. |
| 23:18        | /              | /               | /                                                                                                                                                                                                                                                                      |
| 17:16        | R/W            | 0x0             | CLK_RAT_N<br>Clock pre-divide ratio (n)                                                                                                                                                                                                                                |

|      |     |     |                                                                                                                 |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------|
|      |     |     | The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                                       |
| 15:5 | /   | /   | /                                                                                                               |
| 4:0  | R/W | 0x0 | CLK_RAT_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 32. |

#### 6.4.16. AXI Module Clock Gating (Default: 0x00000000)

| Offset: 0x5C |                |                 | Register Name: AXI_GATING_REG                                      |
|--------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                        |
| 31:1         | /              | /               | /                                                                  |
| 0            | R/W            | 0x0             | DRAM_AXI_GATING.<br>Gating AXI Clock for SDRAM (0: mask, 1: pass). |

#### 6.4.17. AHB Module Clock Gating Register 0(Default: 0x00000000)

| Offset: 0x60 |                |                 | Register Name: AHB_GATING_REG0                                            |
|--------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                               |
| 31:29        | /              | /               | /                                                                         |
| 28           | R/W            | 0x0             | STIMER_AHB_GATING.<br>Gating AHB Clock for Sync timer (0: mask, 1: pass). |
| 27           | /              | /               | /                                                                         |
| 26           | R/W            | 0x0             | GPS_AHB_GATING.<br>Gating AHB Clock for GPS (0: mask, 1: pass).           |
| 25:23        | /              | /               | /                                                                         |
| 22           | R/W            | 0x0             | SPI2_AHB_GATING.<br>Gating AHB Clock for SPI2 (0: mask, 1: pass).         |
| 21           | R/W            | 0x0             | SPI1_AHB_GATING.<br>Gating AHB Clock for SPI1 (0: mask, 1: pass).         |
| 20           | R/W            | 0x0             | SPI0_AHB_GATING.<br>Gating AHB Clock for SPI0 (0: mask, 1: pass).         |
| 19           | /              | /               | /                                                                         |
| 18           | R/W            | 0x0             | TS_AHB_GATING.<br>Gating AHB Clock for TS (0: mask, 1: pass).             |
| 17           | R/W            | 0x0             | EMAC_AHB_GATING.<br>Gating AHB Clock for EMAC (0: mask, 1: pass).         |
| 16:15        | /              | /               | /                                                                         |
| 14           | R/W            | 0x0             | SDRAM_AHB_GATING.<br>Gating AHB Clock for SDRAM (0: mask, 1: pass).       |
| 13           | R/W            | 0x0             | NAND_AHB_GATING.<br>Gating AHB Clock for NAND (0: mask, 1: pass).         |
| 12           | R/W            | 0x0             | /                                                                         |

|     |     |     |                                                                        |
|-----|-----|-----|------------------------------------------------------------------------|
| 11  | /   | /   | /                                                                      |
| 10  | R/W | 0x0 | SD2_AHB_GATING.<br>Gating AHB Clock for SD/MMC2 (0: mask, 1: pass).    |
| 9   | R/W | 0x0 | SD1_AHB_GATING.<br>Gating AHB Clock for SD/MMC1 (0: mask, 1: pass).    |
| 8   | R/W | 0x0 | SD0_AHB_GATING.<br>Gating AHB Clock for SD/MMC0 (0: mask, 1: pass).    |
| 7   | R/W | 0x0 | BIST_AHB_GATING.<br>Gating AHB Clock for BIST (0: mask, 1: pass).      |
| 6   | R/W | 0x0 | DMA_AHB_GATING.<br>Gating AHB Clock for DMA (0: mask, 1: pass).        |
| 5   | R/W | 0x0 | SS_AHB_GATING.<br>Gating AHB Clock for SS (0: mask, 1: pass).          |
| 4:3 | /   | /   | /                                                                      |
| 2   | R/W | 0x0 | OHCI_AHB_GATING.<br>Gating AHB Clock for USB OHCI (0: mask, 1: pass).  |
| 1   | R/W | 0x0 | EHCI_AHB_GATING.<br>Gating AHB Clock for USB EHCI (0: mask, 1: pass).  |
| 0   | R/W | 0x0 | USBDRD_AHB_GATING.<br>Gating AHB Clock for USB DRD (0: mask, 1: pass). |

#### 6.4.18. AHB Module Clock Gating Register 1(Default: 0x00000000)

| Offset: 0x64 |                |                 | Register Name: AHB_GATING_REG1                                    |
|--------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                       |
| 31:21        | /              | /               | /                                                                 |
| 20           | R/W            | 0x0             | Gating AHB Clock for Mali-400(0: mask, 1: pass).                  |
| 19           | R/W            | 0x0             | IEP_AHB_GATING.<br>Gating AHB Clock for IEP (0: mask, 1: pass).   |
| 18:15        | /              | /               | /                                                                 |
| 14           | R/W            | 0x0             | FE_AHB_GATING.<br>Gating AHB Clock for DE-FE (0: mask, 1: pass).  |
| 13           | /              | /               | /                                                                 |
| 12           | R/W            | 0x0             | BE_AHB_GATING.<br>Gating AHB Clock for DE-BE (0: mask, 1: pass).  |
| 11           | R/W            | 0x0             | HDMI_AHB_GATING.<br>Gating AHB Clock for HDMI (0: mask, 1: pass). |
| 10:9         | /              | /               | /                                                                 |
| 8            | R/W            | 0x0             | CSI_AHB_GATING.<br>Gating AHB Clock for CSI (0: mask, 1: pass).   |
| 7:5          | /              | /               | /                                                                 |
| 4            | R/W            | 0x0             | LCD_AHB_GATING.                                                   |

|   |     |     |                                                                 |
|---|-----|-----|-----------------------------------------------------------------|
|   |     |     | Gating AHB Clock for LCD (0: mask, 1: pass).                    |
| 3 | /   | /   | /                                                               |
| 2 | R/W | 0x0 | TVE_AHB_GATING.<br>Gating AHB Clock for TVE (0: mask, 1: pass). |
| 1 | /   | /   | /                                                               |
| 0 | R/W | 0x0 | VE_AHB_GATING.<br>Gating AHB Clock for VE (0: mask, 1: pass).   |

#### 6.4.19. APB0 Module Clock Gating (Default: 0x00000000)

| Offset: 0x68 |                |                 | Register Name: APB0_GATING_REG                                            |
|--------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                               |
| 31:11        | /              | /               | /                                                                         |
| 10           | R/W            | 0x0             | KEYPAD_APB_GATING.<br>Gating APB Clock for Keypad (0: mask, 1: pass).     |
| 9:7          | /              | /               | /                                                                         |
| 6            | R/W            | 0x0             | IR_APB_GATING.<br>Gating APB Clock for IR (0: mask, 1: pass).             |
| 5            | R/W            | 0x0             | PIO_APB_GATING.<br>Gating APB Clock for PIO (0: mask, 1: pass).           |
| 4            | /              | /               | /                                                                         |
| 3            | R/W            | 0x0             | IIS_APB_GATING.<br>Gating APB Clock for IIS (0: mask, 1: pass).           |
| 2            | /              | /               | /                                                                         |
| 1            | R/W            | 0x0             | /                                                                         |
| 0            | R/W            | 0x0             | CODEC_APB_GATING.<br>Gating APB Clock for Audio CODEC (0: mask, 1: pass). |

#### 6.4.20. APB1 Module Clock Gating (Default: 0x00000000)

| Offset: 0x6C |                |                 | Register Name: APB1_GATING_REG                                      |
|--------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                         |
| 31:24        | /              | /               | /                                                                   |
| 23           | /              | /               | /                                                                   |
| 22           | /              | /               | /                                                                   |
| 21           | /              | /               | /                                                                   |
| 20           | /              | /               | /                                                                   |
| 19           | R/W            | 0x0             | UART3_APB_GATING.<br>Gating APB Clock for UART3 (0: mask, 1: pass). |
| 18           | R/W            | 0x0             | UART2_APB_GATING.<br>Gating APB Clock for UART2 (0: mask, 1: pass). |
| 17           | R/W            | 0x0             | UART1_APB_GATING.                                                   |

|      |     |     |                                                                     |
|------|-----|-----|---------------------------------------------------------------------|
|      |     |     | Gating APB Clock for UART1 (0: mask, 1: pass).                      |
| 16   | R/W | 0x0 | UART0_APB_GATING.<br>Gating APB Clock for UART0 (0: mask, 1: pass). |
| 15:8 | /   | /   | /                                                                   |
| 7    | /   | /   | /                                                                   |
| 6    | /   | /   | /                                                                   |
| 5    | /   | /   | /                                                                   |
| 4    | /   | /   | /                                                                   |
| 3    | /   | /   | /                                                                   |
| 2    | R/W | 0x0 | TWI2_APB_GATING.<br>Gating APB Clock for TWI2 (0: mask, 1: pass).   |
| 1    | R/W | 0x0 | TWI1_APB_GATING.<br>Gating APB Clock for TWI1 (0: mask, 1: pass).   |
| 0    | R/W | 0x0 | TWI0_APB_GATING.<br>Gating APB Clock for TWI0 (0: mask, 1: pass).   |

#### 6.4.21. NAND Clock (Default: 0x00000000)

| Offset: 0x80 |                |                 | Register Name: NAND_SCLK_CFG_REG                                                                                                                        |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /                                                                      |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                    |

Note: In application, the module clock frequency always switches off.

#### 6.4.22. SD0 Clock (Default: 0x00000000)

| Offset: 0x88 |                |                 | Register Name: SD0_SCLK_CFG_REG                                                                                                                         |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /.                                                                     |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                   |

#### 6.4.23. SD1 Clock (Default: 0x00000000)

| Offset: 0x8C |                |                 | Register Name: SD1_SCLK_CFG_REG                                                                                                                         |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /.                                                                     |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.                                                                                                                                        |

|      |     |     |                                                                                                                       |
|------|-----|-----|-----------------------------------------------------------------------------------------------------------------------|
|      |     |     | Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.               |
| 15:4 | /   | /   | /                                                                                                                     |
| 3:0  | R/W | 0x0 | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |

#### 6.4.24. SD2 Clock (Default: 0x00000000)

| Offset: 0x90 |                |                 | Register Name: SD2_SCLK_CFG_REG                                                                                                                         |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /.                                                                     |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                   |

#### 6.4.25. TS Clock (Default: 0x00000000)

| Offset: 0x98 |                |                 | Register Name: TS_SCLK_CFG_REG                                                                                                                          |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.                                                                                                                                            |

|       |     |     |                                                                                                                             |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------|
|       |     |     | Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /.                                                         |
| 23:18 | /   | /   | /                                                                                                                           |
| 17:16 | R/W | 0x0 | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8. |
| 15:4  | /   | /   | /                                                                                                                           |
| 3:0   | R/W | 0x0 | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.       |

#### 6.4.26. SS Clock (Default: 0x00000000)

| Offset: 0x9C |                |                 | Register Name: SS_SCLK_CFG_REG                                                                                                                          |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /                                                                      |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                   |

#### 6.4.27. SPI0 Clock (Default: 0x00000000)

| Offset: 0xA0 |                |                 | Register Name: SPI 0_SCLK_CFG_REG |
|--------------|----------------|-----------------|-----------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                       |

|       |     |     |                                                                                                                                                         |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W | 0x0 | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26 | /   | /   | /                                                                                                                                                       |
| 25:24 | R/W | 0x0 | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /                                                                      |
| 23:18 | /   | /   | /                                                                                                                                                       |
| 17:16 | R/W | 0x0 | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4  | /   | /   | /                                                                                                                                                       |
| 3:0   | R/W | 0x0 | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                   |

#### 6.4.28. SPI1 Clock (Default: 0x00000000)

| Offset: 0xA4 |                |                 | Register Name: SPI1_SCLK_CFG_REG                                                                                                                        |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /                                                                      |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.                                                                                                                                        |

|  |  |  |                                                                                                   |
|--|--|--|---------------------------------------------------------------------------------------------------|
|  |  |  | Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |
|--|--|--|---------------------------------------------------------------------------------------------------|

#### 6.4.29. SPI2 Clock (Default: 0x00000000)

| Offset: 0xA8 |                |                 | Register Name: SPI2_SCLK_CFG_REG                                                                                                                        |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 200MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5<br>11: /                                                                      |
| 23:18        | /              | /               | /                                                                                                                                                       |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.                             |
| 15:4         | /              | /               | /                                                                                                                                                       |
| 3:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                                   |

#### 6.4.30. IR Clock (Default: 0x00000000)

| Offset: 0xB0 |                |                 | Register Name: IR_SCLK_CFG_REG                                                                                                                          |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 100MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL5                                                                                |

|       |     |     |                                                                                                                           |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 11: /                                                                                                                     |
| 23:18 | /   | /   | /                                                                                                                         |
| 17:16 | R/W | 0x0 | CLK_DIV_RATIO.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8. |
| 15:4  | /   | /   | /                                                                                                                         |
| 3:0   | R/W | 0x0 | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.     |

#### 6.4.31. IIS Clock (Default: 0x00000000)

| Offset: 0xB8 |                |                 | Register Name: IIS_SCLK_CFG_REG                                                                                                                               |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                   |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 100MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N.                 |
| 30:25        | /              | /               | /                                                                                                                                                             |
| 24           | /              | /               | /                                                                                                                                                             |
| 23:18        | /              | /               | /                                                                                                                                                             |
| 17:16        | R/W            | 0x0             | CLK_DIV_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8.<br>The clock source is PLL2 (8x). |
| 15:4         | /              | /               | /                                                                                                                                                             |
| 3:0          | /              | /               | /                                                                                                                                                             |

#### 6.4.32. Keypad Register (Default: 0x00000000)

| Offset: 0xC4 |                |                 | Register Name:                                                                                                                                          |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31           | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 100MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider N/Divider M. |
| 30:26        | /              | /               | /                                                                                                                                                       |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>0: OSC24M                                                                                                        |

|       |     |      |                                                                                                                         |
|-------|-----|------|-------------------------------------------------------------------------------------------------------------------------|
|       |     |      | 1: /<br>2: LOSC clock (32KHz)<br>3: /                                                                                   |
| 23:18 | /   | /    | /                                                                                                                       |
| 17:16 | R/W | 0x0  | CLK_RATIO_N.<br>Clock pre-divide ratio (n)<br>The select clock source is pre-divided by $2^n$ . The divider is 1/2/4/8. |
| 15:5  | /   | /    | /                                                                                                                       |
| 4:0   | R/W | 0x1f | CLK_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 32.       |

#### 6.4.33. USB Clock (Default: 0x00000000)

| Offset: 0xCC |                |                 | Register Name: USBPHY_CFG_REG                                                                 |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                   |
| 31:10        | /              | /               | /                                                                                             |
| 9            | R/W            | 0x0             | USBPHY1_CLK_GATING.<br>Gating Special Clock for USB PHY1<br>0: Clock is OFF<br>1: Clock is ON |
| 8            | R/W            | 0x0             | USBPHY0_CLK_GATING.<br>Gating Special Clock for USB PHY0<br>0: Clock is OFF<br>1: Clock is ON |
| 7            | /              | /               | /                                                                                             |
| 6            | R/W            | 0x0             | OHCI_SCLK_GATING.<br>Gating Special Clock for OHCI<br>0: Clock is OFF<br>1: Clock is ON       |
| 5            | /              | /               | /                                                                                             |
| 4            | /              | /               | /                                                                                             |
| 3            | /              | /               | /                                                                                             |
| 2            | /              | /               | /                                                                                             |
| 1            | R/W            | 0x0             | USBPHY1_RST_CTRL.<br>USB PHY1 Reset Control<br>0: Reset valid<br>1: Reset invalid             |
| 0            | R/W            | 0x0             | USBPHY0_RST_CTRL.<br>USB PHY0 Reset Control<br>0: Reset valid<br>1: Reset invalid             |

#### 6.4.34. GPS Clock (Default: 0x80000000)

| Offset: 0xD0 |                |                 | Register Name: GPS_CFG_REG                                                                                           |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                          |
| 31           | R/W            | 0x1             | GPS_SCLK_GATING.<br>Gating Special Clock for GPS.<br>0: Clock is OFF<br>1: Clock is ON                               |
| 30           | R/W            | 0x0             | GPS_RST_CTRL.<br>GPS Reset Control<br>0: Reset valid<br>1: Reset invalid                                             |
| 29:26        | /              | /               | /                                                                                                                    |
| 25:24        | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: OSC24M<br>01: PLL6<br>10: PLL7<br>11: PLL4.                               |
| 23:3         | /              | /               | /                                                                                                                    |
| 2:0          | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 8. |

#### 6.4.35. DRAM CLK (Default: 0x00000000)

| Offset: 0x100 |                |                 | Register Name: DRAM_SCLK_CFG_REG                                   |
|---------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 31            | R/W            | 0x0             | IEP_DCLK_GATING.<br>Gating DRAM Clock for IEP (0: mask, 1: pass).  |
| 30            | /              | /               | /                                                                  |
| 29            | R/W            | 0x0             | ACE_DCLK_GATING.<br>Gating DRAM Clock for ACE (0: mask, 1: pass).  |
| 28            | /              | /               | /                                                                  |
| 27            | /              | /               | /                                                                  |
| 26            | R/W            | 0x0             | BE_DCLK_GATING.<br>Gating DRAM Clock for DE_BE (0: mask, 1: pass). |
| 25            | R/W            | 0x0             | FE_DCLK_GATING.<br>Gating DRAM Clock for DE_FE (0: mask, 1: pass). |
| 24            | /              | /               | /                                                                  |
| 23:16         | /              | /               | /                                                                  |
| 15            | /              | /               | /                                                                  |

|      |     |     |                                                                   |
|------|-----|-----|-------------------------------------------------------------------|
| 14:7 | /   | /   | /                                                                 |
| 6    | /   | /   | /                                                                 |
| 5    | R/W | 0x0 | TVE_DCLK_GATING.<br>Gating DRAM Clock for TVE (0: mask, 1: pass). |
| 4    | /   | /   | /                                                                 |
| 3    | R/W | 0x0 | TS_DCLK_GATING.<br>Gating DRAM Clock for TS (0: mask, 1: pass).   |
| 2    | /   | /   | /                                                                 |
| 1    | R/W | 0x0 | CSI_DCLK_GATING.<br>Gating DRAM Clock for CSI (0: mask, 1: pass). |
| 0    | R/W | 0x0 | VE_DCLK_GATING.<br>Gating DRAM Clock for VE (0: mask, 1: pass).   |

#### 6.4.36. DE-BE Clock (Default: 0x00000000)

| Offset: 0x104 |                |                 | Register Name: BE_CFG_REG                                                                                                 |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                               |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0             | BE_RST.<br>DE-BE Reset.<br>0: reset valid, 1: reset invalid.                                                              |
| 29:26         | /              | /               | /                                                                                                                         |
| 25:24         | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: PLL3<br>01: PLL7<br>10: PLL5<br>11: /.                                         |
| 23:18         | /              | /               | /                                                                                                                         |
| 17:16         | /              | /               | /                                                                                                                         |
| 15:4          | /              | /               | /                                                                                                                         |
| 3:0           | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.     |

#### 6.4.37. DE-FE Clock(Default: 0x00000000)

| Offset: 0x10C |        |          | Register Name: FE_CFG_REG |
|---------------|--------|----------|---------------------------|
| Bit           | Read/W | Default/ | Description               |

|       | rite | Hex |                                                                                                                           |
|-------|------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W  | 0x0 | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30    | R/W  | 0x0 | FE_RST.<br>DE-FE Reset.<br>0: reset valid, 1: reset invalid.                                                              |
| 29:26 | /    | /   | /                                                                                                                         |
| 25:24 | R/W  | 0x0 | CLK_SRC_SEL.<br>Clock Source Select<br>00: PLL3<br>01: PLL7<br>10: PLL5<br>11: /.                                         |
| 23:18 | /    | /   | /                                                                                                                         |
| 17:16 | /    | /   | /                                                                                                                         |
| 15:4  | /    | /   | /                                                                                                                         |
| 3:0   | R/W  | 0x0 | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.     |

#### 6.4.38. LCD CH0 TVE Clock (Default: 0x00000000)

| Offset: 0x118 |                |                 | Register Name: LCD_CH0_TVE_CFG_REG                                                                             |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                    |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source |
| 30            | R/W            | 0x0             | LCD_RST.<br>LCD Reset.<br>0: reset valid, 1: reset invalid.                                                    |
| 29            | R/W            | 0x0             | TVE_RST.<br>TV Encoder Reset.<br>0: reset valid, 1: reset invalid.                                             |
| 28:26         | /              | /               | /                                                                                                              |
| 25:24         | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: PLL3(1X)<br>01: PLL7(1X)                                            |

|       |   |   |                              |
|-------|---|---|------------------------------|
|       |   |   | 10: PLL3(2X)<br>11: PLL7(2X) |
| 23:18 | / | / | /                            |
| 17:16 | / | / | /                            |
| 15:4  | / | / | /                            |
| 3:0   | / | / | /.<br>/.                     |

#### 6.4.39. LCD CH1 Clock (Default: 0x00000000)

| Offset: 0x12C |                |                 | Register Name: LCD_CH1_CFG_REG                                                                                                          |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                             |
| 31            | R/W            | 0x0             | SCLK2_GATING.<br>Gating Special Clock 2<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock 2= Special Clock 2 Source/Divider M. |
| 30:26         | /              | /               | /                                                                                                                                       |
| 25:24         | R/W            | 0x0             | SCLK2_SRC_SEL.<br>Special Clock 2 Source Select<br>00: PLL3(1X)<br>01:PLL7(1X)<br>10: PLL3(2X)<br>11: PLL7(2X)                          |
| 23:18         | /              | /               | /                                                                                                                                       |
| 17:16         | R/W            | 0x0             | /                                                                                                                                       |
| 15            | /              | /               | SCLK1_GATING.<br>Gating Special Clock 1<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock 1= Special Clock 1 Source.           |
| 14:12         | /              | /               | /                                                                                                                                       |
| 11            | R/W            | 0x0             | SCLK1_SRC_SEL.<br>Special Clock 1 Source Select.<br>0: Special Clock 2<br>1: Special Clock 2 divide by 2                                |
| 10:4          | /              | /               | /                                                                                                                                       |
| 3:0           | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                   |

#### 6.4.40. CSI Clock (Default: 0x00000000)

|               |                            |
|---------------|----------------------------|
| Offset: 0x134 | Register Name: CSI_CFG_REG |
|---------------|----------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                          |
|-------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M.                            |
| 30    | R/W            | 0x0             | CSI_RST.<br>CSI Reset.<br>0: reset valid, 1: reset invalid.                                                                                          |
| 29:27 | /              | /               | /                                                                                                                                                    |
| 26:24 | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>000: OSC24M<br>001: PLL3(1X)<br>010: PLL7(1X)<br>011: /<br>100: /<br>101: PLL3(2X)<br>110: PLL7(2X)<br>111: / |
| 23:18 | /              | /               | /                                                                                                                                                    |
| 17:16 | /              | /               | /                                                                                                                                                    |
| 15:5  | /              | /               | /                                                                                                                                                    |
| 4:0   | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 32.                                |

#### 6.4.41. VE Clock (Default: 0x00000000)

| Offset: 0x13C |                | Register Name: VE_CFG_REG |                                                                                                                                         |
|---------------|----------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex           | Description                                                                                                                             |
| 31            | R/W            | 0x0                       | SCLK_GATING.<br>Gating the Special clock for VE (0: mask, 1: pass).<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock is PLL4. |
| 25:24         | /              | /                         | /                                                                                                                                       |
| 30:20         | /              | /                         | /                                                                                                                                       |
| 19:16         | /              | /                         | /                                                                                                                                       |
| 15:1          | /              | /                         | /                                                                                                                                       |
| 0             | R/W            | 0x0                       | VE_RST.<br>VE Reset.                                                                                                                    |

|  |  |  |                                   |
|--|--|--|-----------------------------------|
|  |  |  | 0: reset valid, 1: reset invalid. |
|--|--|--|-----------------------------------|

#### 6.4.42. Audio Codec Clock (Default: 0x00000000)

| Offset: 0x140 |                |                 | Register Name: AUDIO_CODEC_SCLK_CFG_REG                                                                        |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                    |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = PLL2 output. |
| 30:0          | /              | /               | /                                                                                                              |

#### 6.4.43. AVS Clock (Default: 0x00000000)

| Offset: 0x144 |                |                 | Register Name: AVS_SCLK_CFG_REG                                                                           |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                               |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = OSC24M. |
| 30:0          | /              | /               | /                                                                                                         |

#### 6.4.44. HDMI Clock (Default: 0x00000000)

| Offset: 0x150 |                |                 | Register Name: HDMI_SCLK_CFG_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                               |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/ Divider M |
| 30:26         | /              | /               | /                                                                                                                         |
| 25:24         | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>00: PLL3(1X)<br>01: /<br>10: PLL3(2X)<br>11: /                                     |
| 23:4          | /              | /               | /                                                                                                                         |
| 3:0           | R/W            | 0x0             | CLK_DIV_RATIO_M.<br>Clock divide ratio (m)                                                                                |

|  |  |                                                                         |
|--|--|-------------------------------------------------------------------------|
|  |  | The pre-divided clock is divided by (m+1). The divider is from 1 to 16. |
|--|--|-------------------------------------------------------------------------|

#### 6.4.45. Mali-400 Clock Register(Default: 0x00000000)

| Offset: 0x154 |                |                 | Register Name: MALI_CLOCK_CFG_REG                                                                                                             |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                   |
| 31            | R/W            | 0x0             | SCLK_GATING.<br>Gating Special Clock(Max Clock = 381MHz)<br>0: Clock is OFF<br>1: Clock is ON<br>This special clock = Clock Source/Divider M. |
| 30            | R/W            | 0x0             | MALI400_RST.<br>Mali400 Reset.<br>0: reset valid, 1: reset invalid                                                                            |
| 29:27         | /              | /               | /                                                                                                                                             |
| 26:24         | R/W            | 0x0             | CLK_SRC_SEL.<br>Clock Source Select<br>000: PLL3(1X)<br>001: PLL4<br>010: PLL5<br>011: PLL7 (1X).<br>100: PLL7(2X)                            |
| 23:18         | /              | /               | /                                                                                                                                             |
| 17:16         | /              | /               | /                                                                                                                                             |
| 15:4          | /              | /               | /.                                                                                                                                            |
| 3:0           | R/W            | 0x0             | CLK_DIV_RATIO_M<br>Clock divide ratio (m)<br>The pre-divided clock is divided by (m+1). The divider is from 1 to 16.                          |

#### 6.4.46. MBUS Clock Control (Default: 0x00000000)

| Offset: 0x15C |                |                 | Register Name: MBUS_SCLK_CFG_REG                                                                                                                        |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31            | R/W            | 0x0             | MBUS_SCLK_GATING.<br>Gating Clock for MBUS (Max Clock = 300MHz)<br>0: Clock is OFF,<br>1: Clock is ON;<br>MBUS_CLOCK = Clock Source/Divider N/Divider M |
| 30:26         | /              | /               | /                                                                                                                                                       |
| 25:24         | R/W            | 0x0             | MBUS_SCLK_SRC<br>Clock Source Select<br>00: OSC24M<br>01: PLL6                                                                                          |

|       |     |     |                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 10: PLL5<br>11: Reserved                                                                                                     |
| 23:18 | /   | /   | /                                                                                                                            |
| 17:16 | R/W | 0x0 | MBUS_SCLK_RATIO_N<br>Clock Pre-divide Ratio (N)<br>The select clock source is pre-divided by $2^N$ . The divider is 1/2/4/8. |
| 15:4  | /   | /   | /                                                                                                                            |
| 3:0   | R/W | 0x0 | MBUS_SCLK_RATIO_M<br>Clock Divide Ratio (M)<br>The divided clock is divided by (M+1). The divider is from 1 to 16.           |

#### 6.4.47. IEP Clock Control (Default: 0x00000000)

| Offset: 0x160 |                |                 | Register Name: IEP_SCLK_CFG_REG                                                                                              |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                  |
| 31            | R/W            | 0x0             | IEP_SCLK_GATING.<br>Gating Clock for IEP (Max Clock = 300MHz)<br>0: Clock is OFF,<br>1: Clock is ON;<br>IEP_CLOCK = BE Clock |
| 30            | R/W            | 0x0             | IEP_RST.<br>IEP Reset.<br>0: reset valid, 1: reset invalid.                                                                  |
| 29:0          | /              | /               | /                                                                                                                            |

## 7. System Control

### 7.1. Overview

The chip embeds a high-speed SRAM, which is split into five areas. Its Memory Mapping is detailed in the following table:

| Area         | Address                | Size(Bytes) |
|--------------|------------------------|-------------|
| A1           | 0x00000000--0x00003FFF | 16K         |
| A2           | 0x00004000--0x00007FFF | 16K         |
| A3           | 0x00008000--0x0000B3FF | 13K         |
| A4           | 0x0000B400--0x0000BFFF | 3K          |
| C1           | 0x01D00000-0x01D7FFFF  | VE          |
| C3           | 0x01DC0000-0x01DCFFFF  | ISP         |
| NAND         |                        | 2K          |
| D( USB )     | 0x00010000—0x00010FFF  | 4K          |
| CPU I-Cache  |                        | 32K         |
| CPU D-Cache  |                        | 32K         |
| CPU L2 Cache |                        | 128K        |

### 7.2. System Control Register List

| Module Name | Base Address |
|-------------|--------------|
| SRAM        | 0x01C00000   |

| Register Name | Offset | Description        |
|---------------|--------|--------------------|
| SRAM_CFG_REG0 | 0x0000 | SRAM Configuration |
| SRAM_CFG_REG1 | 0x0004 | SRAM Control       |

### 7.3. System Control Register Description

#### 7.3.1. SRAM Configuration Register 0(Default: 0x7FFFFFFF)

|              |                |                 |                                                                                                   |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------|
| Offset: 0x00 |                |                 | Register Name: SRAM_CFG_REG0                                                                      |
| Bit          | Read/<br>Write | Default/H<br>ex | Description                                                                                       |
| 31           | /              | /               | /                                                                                                 |
| 30:0         | R/W            | 0x7fffffff      | SRAM_C1_MAP.<br>SRAM Area C1 50K Bytes Configuration by AHB.<br>0: map to CPU/DMA<br>1: map to VE |

#### 7.3.2. SRAM Configuration Register 1(Default: 0x00001000)

|              |                              |
|--------------|------------------------------|
| Offset: 0x04 | Register Name: SRAM_CFG_REG1 |
|--------------|------------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                                                                   |
|-------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------|
| 31    | R/W            | 0x0             | /                                                                                                             |
| 30:18 | /              | /               | /                                                                                                             |
| 17    | R/W            | 0x0             | /                                                                                                             |
| 16    | R/W            | 0x0             | /                                                                                                             |
| 15:14 | R/W            | 0x0             | /                                                                                                             |
| 13    | /              | /               | /                                                                                                             |
| 12    | R/W            | 0x1             | SRAM_C3_MAP.<br>SRAM C3 map config.<br>0: map to CPU/BIST<br>1: map to ISP                                    |
| 11:6  | /              | /               | /                                                                                                             |
| 5:4   | R/W            | 0x0             | SRAM_A3_A4_MAP.<br>SRAM Area A3/A4 Configuration by AHB.<br>00: map to CPU/DMA<br>01: map to EMAC<br>10/11: / |
| 3:1   | /              | /               | /                                                                                                             |
| 0     | R/W            | 0x0             | SRAM_D_MAP.<br>SRAM D Area Config.<br>0: map to CPU/DMA<br>1: map to USB-DRD                                  |

## 8. CPU Control

### 8.1. CPU Register List

| Module Name | Base Address |
|-------------|--------------|
| CPU CTL     | 0x01C23400   |

| Register Name | Offset | Description          |
|---------------|--------|----------------------|
| CPU_CTRL_REG  | 0x0020 | CPU Control Register |

### 8.2. CPU Control Register Description

#### 8.2.1. CPU Control Register(Default :0x00000002)

| Offset: 0x20 |                |                 | Register Name: CPU_CTRL_REG                                                                       |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                       |
| 31:9         | /              | /               | /.                                                                                                |
| 8            | R/W            | 0x0             | CPU_ID.<br>CPU ID Option.                                                                         |
| 7:2          | /              | /               | /                                                                                                 |
| 1            | R/W            | 0x1             | /                                                                                                 |
| 0            | R/W            | 0x0             | CP15_WRITE_DISABLE.<br>Disable write access to certain CP15 registers.<br>0: enable<br>1: disable |

## 9. SDRAM Controller

### 9.1. Overview

The SDRAM Controller (DRAMC) provides a simple, flexible, burst-optimized interface to all industry-standard double data rate II (DDR2) ordinary SDRAM and Double data rate III (DDR3) ordinary SDRAM. It supports up to a 16G bits memory address space.

The DRAMC automatically handles memory management, initialization, and refresh operations. It gives the host CPU a simple command interface, hiding details of the required address, page, and burst handling procedures. All memory parameters are runtime-configurable, including timing, memory setting, SDRAM type, and Extended-Mode-Register settings.

The DRAMC includes following features:

- Support DDR2 SDRAM and DDR3 SDRAM
- Support different memory device power voltage of 1.5V and 1.8V
- Support DDR2/3 SDRAM of clock frequency up to DDR1066
- Support memory capacity up to 16G bits (2G Bytes)
- Support 2 chip select signals
- 15 address lines and 3 bank address lines
- Data IO size can up to 32-bit for DDR2 and DDR3 (x8, x16)
- Automatically generate initialization and refresh sequences
- Runtime-configurable parameters setting for application flexibility
- Clock frequency can be chosen for different applications
- Priority of transferring through multiple ports is programmable
- Support random read or write operation

# 10. Pulse Width Modulator (PWM)

## 10.1. Overview

The output of the PWM is a toggling signal whose frequency and duty cycle can be modulated by its programmable registers. Each channel has a dedicated internal 16-bit up counter. If the counter reaches the value stored in the channel period register, it resets. At the beginning of a count period cycle, the PWMOUT is set to activate state and count from 0x0000.

The PWM divider divides the clock (24MHz) by 1-4096 according to the pre-scalar bits in the PWM control register.

In PWM cycle mode, the output will be a square waveform; the frequency is set to the period register.

In PWM pulse mode, the output will be a positive pulse or a negative pulse.

## 10.2. PWM Register List

| Module Name | Base Address |
|-------------|--------------|
| PWM         | 0x01C20C00   |

| Register Name      | Offset | Description                   |
|--------------------|--------|-------------------------------|
| PWM_CTRL_REG       | 0x0200 | PWM Control Register          |
| PWM_CH0_PERIOD_REG | 0x0204 | PWM Channel 0 Period Register |
| PWM_CH1_PERIOD_REG | 0x0208 | PWM Channel 1 Period Register |

## 10.3. PWM Register Description

### 10.3.1. PWM Control Register (Default: 0x00000000)

| Offset: 0x200 |                |                 | Register Name: PWM_CTRL_REG                                                                                                |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                |
| 31:30         | /              | /               | /                                                                                                                          |
| 29            | R/W            | 0x0             | PWM1_RDY.<br>PWM1 period register ready.<br>0: PWM1 period register is ready to write,<br>1: PWM1 period register is busy. |
| 28            | R/W            | 0x0             | PWM0_RDY.<br>PWM0 period register ready.<br>0: PWM0 period register is ready to write,<br>1: PWM0 period register is busy. |
| 27:25         | /              | /               | /                                                                                                                          |
| 24            | R/W            | 0x0             | PWM1_BYPASS.<br>PWM CH1 bypass enable.<br>If the bit is set to 1, PWM1's output is OSC24MHz.                               |

|       |     |     |                                                                                                                                                                                                                                                                                                                                     |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0: disable,<br>1: enable.                                                                                                                                                                                                                                                                                                           |
| 23    | R/W | 0x0 | PWM_CH1_PULSE_OUT_START.<br>PWM Channel 1 pulse output start.<br>0: no effect, 1: output 1 pulse.<br>The pulse width should be according to the period 1 register [15:0], and<br>the pulse state should be according to the active state.<br>After the pulse is finished, the bit will be cleared automatically.                    |
| 22    | R/W | 0x0 | PWM_CH1_MODE.<br>PWM Channel 1 mode.<br>0: cycle mode, 1: pulse mode.                                                                                                                                                                                                                                                               |
| 21    | R/W | 0x0 | PWM_CH1_CLK_GATING<br>Gating the Special Clock for PWM1 (0: mask, 1: pass).                                                                                                                                                                                                                                                         |
| 20    | R/W | 0x0 | PWM_CH1_ACT_STATE.<br>PWM Channel 1 Active State.<br>0: Low Level, 1: High Level.                                                                                                                                                                                                                                                   |
| 19    | R/W | 0x0 | PWM_CH1_EN.<br>PWM Channel 1 Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                                                                                      |
| 18:15 | R/W | 0x0 | PWM_CH1_PRESCAL.<br>PWM Channel 1 Prescalar.<br>These bits should be setting before the PWM Channel 1 clock gate on.<br>0000: /120<br>0001: /180<br>0010: /240<br>0011: /360<br>0100: /480<br>0101: /<br>0110: /<br>0111: /<br>1000: /12k<br>1001: /24k<br>1010: /36k<br>1011: /48k<br>1100: /72k<br>1101: /<br>1110: /<br>1111: /1 |
| 14:10 | /   | /   | /                                                                                                                                                                                                                                                                                                                                   |
| 9     | R/W | 0x0 | PWM0_BYPASS.<br>PWM CH0 bypass enable.<br>If the bit is set to 1, PWM0's output is OSC24MHz.<br>0: disable,                                                                                                                                                                                                                         |

|     |     |     |                                                                                                                                                                                                                                                                                                                                     |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 1: enable.                                                                                                                                                                                                                                                                                                                          |
| 8   | R/W | 0x0 | PWM_CH0_PUL_START.<br>PWM Channel 0 pulse output start.<br>0: no effect, 1: output 1 pulse.<br>The pulse width should be according to the period 0 register [15:0], and the pulse state should be according to the active state.<br>After the pulse is finished, the bit will be cleared automatically.                             |
| 7   | R/W | 0x0 | PWM_CHANNEL0_MODE.<br>0: cycle mode, 1: pulse mode.                                                                                                                                                                                                                                                                                 |
| 6   | R/W | 0x0 | SCLK_CH0_GATING.<br>Gating the Special Clock for PWM0 (0: mask, 1: pass).                                                                                                                                                                                                                                                           |
| 5   | R/W | 0x0 | PWM_CH0_ACT_STA.<br>PWM Channel 0 Active State.<br>0: Low Level, 1: High Level.                                                                                                                                                                                                                                                     |
| 4   | R/W | 0x0 | PWM_CH0_EN.<br>PWM Channel 0 Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                                                                                      |
| 3:0 | R/W | 0x0 | PWM_CH0_PRESCAL.<br>PWM Channel 0 Prescalar.<br>These bits should be setting before the PWM Channel 0 clock gate on.<br>0000: /120<br>0001: /180<br>0010: /240<br>0011: /360<br>0100: /480<br>0101: /<br>0110: /<br>0111: /<br>1000: /12k<br>1001: /24k<br>1010: /36k<br>1011: /48k<br>1100: /72k<br>1101: /<br>1110: /<br>1111: /1 |

### 10.3.2. PWM Channel 0 Period Register

| Offset: 0x204 |                |                 | Register Name: PWM_CH0_PERIOD_REG                             |
|---------------|----------------|-----------------|---------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                   |
| 31:16         | R/W            | x               | PWM_ENT_CYC.<br>Number of the entire cycles in the PWM clock. |

|      |     |   |                                                                                                                                                            |
|------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | <p>0 = 1 cycle<br/>     1 = 2 cycles<br/>     .....<br/>     N = N+1 cycles.</p>                                                                           |
| 15:0 | R/W | x | <p>PWM_ACT_CYC.<br/>     Number of the active cycles in the PWM clock.<br/>     0 = 0 cycle<br/>     1 = 1 cycles<br/>     .....<br/>     N = N cycles</p> |

Note: the active cycles should be no larger than the period cycles.

### 10.3.3. PWM Channel 1 Period Register

| Offset: 0x208 |                | Register Name: PWM_CH1_PERIOD_REG |                                                                                                                                                               |
|---------------|----------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex                   | Description                                                                                                                                                   |
| 31:16         | R/W            | x                                 | <p>PWM_ENT_CYC.<br/>     Number of the entire cycles in the PWM clock.<br/>     0 = 1 cycle<br/>     1 = 2 cycles<br/>     .....<br/>     N = N+1 cycles.</p> |
| 15:0          | R/W            | x                                 | <p>PWM_ACT_CYC.<br/>     Number of the active cycles in the PWM clock.<br/>     0 = 0 cycle<br/>     1 = 1 cycles<br/>     .....<br/>     N = N cycles</p>    |

# 11. Asynchronous Timer

## 11.1. Overview

The chip implements 6 timers.

Timer 0/1/2 can take their inputs from the PLL6/6 or OSC24M. They provide the operating system's scheduler interrupt. It is designed to offer maximum accuracy and efficient management, even for systems with long or short response time. They provide 32-bit programmable overflow counter and work in auto-reload mode or no-reload mode.

The Watchdog is used to resume controller operation by generating a general reset or an interrupt request when it is disturbed by malfunctions such as noise sand system errors. It features a down counter that allows a watchdog period of up to 16 seconds.

Timer 3 is used for OS to generate a periodic interrupt.

## 11.2. ASYNC Timer Register List

| Module Name | Base Address |            |
|-------------|--------------|------------|
| ASYNC Timer |              | 0x01C20C00 |

| Register Name              | Offset | Description            |
|----------------------------|--------|------------------------|
| ASYNC_TMR IRQ_EN_REG       | 0x0000 | Timer IRQ Enable       |
| ASYNC_TMR IRQ_STAS_REG     | 0x0004 | Timer Status           |
| ASYNC_TMR0_CTRL_REG        | 0x0010 | Timer 0 Control        |
| ASYNC_TMR0_INTV_VALUE_REG  | 0x0014 | Timer 0 Interval Value |
| ASYNC_TMR0_CURNT_VALUE_REG | 0x0018 | Timer 0 Current Value  |
| ASYNC_TMR1_CTRL_REG        | 0x0020 | Timer 1 Control        |
| ASYNC_TMR1_INTV_VALUE_REG  | 0x0024 | Timer 1 Interval Value |
| ASYNC_TMR1_CURNT_VALUE_REG | 0x0028 | Timer 1 Current Value  |
| ASYNC_TMR2_CTRL_REG        | 0x0030 | Timer 2 Control        |
| ASYNC_TMR2_INTV_VALUE_REG  | 0x0034 | Timer 2 Interval Value |
| ASYNC_TMR2_CURNT_VALUE_REG | 0x0038 | Timer 2 Current Value  |
| ASYNC_TMR3_CTRL_REG        | 0x0040 | Timer 3 Control        |
| ASYNC_TMR3_INTV_VALUE_REG  | 0x0044 | Timer 3 Interval Value |
| ASYNC_TMR4_CTRL_REG        | 0x0050 | Timer 4 Control        |
| ASYNC_TMR4_INTV_VALUE_REG  | 0x0054 | Timer 4 Interval Value |
| ASYNC_TMR4_CURNT_VALUE_REG | 0x0058 | Timer 4 Current Value  |
| ASYNC_TMR5_CTRL_REG        | 0x0060 | Timer 5 Control        |
| ASYNC_TMR5_INTV_VALUE_REG  | 0x0064 | Timer 5 Interval Value |
| ASYNC_TMR5_CURNT_VALUE_REG | 0x0068 | Timer 5 Current Value  |
| AVS_CNT_CTL_REG            | 0x0080 | AVS Control Register   |
| AVS_CNT0_REG               | 0x0084 | AVS Counter 0 Register |

|                     |        |                            |
|---------------------|--------|----------------------------|
| AVS_CNT1_REG        | 0x0088 | AVS Counter 1 Register     |
| AVS_CNT_DIVISOR_REG | 0x008C | AVS Divisor                |
| WDOG_CTRL_REG       | 0x0090 | Watchdog Control           |
| WDOG_MODE_REG       | 0x0094 | Watchdog Mode              |
| COUNTER64_CTRL_REG  | 0x00A0 | 64-bit Counter control     |
| COUNTER64_LOW_REG   | 0x00A4 | 64-bit Counter low         |
| COUNTER64_HI_REG    | 0x00A8 | 64-bit Counter high        |
| CPU_CFG_REG         | 0x0140 | CPU configuration register |

## 11.3. ASYNC Timer Register Description

### 11.3.1. ASYNC Timer IRQ Enable Register (Default: 0x00000000)

| Offset: 0x00 |                |                 | Register Name: ASYNC_TMR_IRQ_EN_REG                                                                              |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                      |
| 31:9         | /              | /               | /                                                                                                                |
| 8            | R/W            | 0x0             | WDOG_INT_EN.<br>Watchdog Interrupt Enable.<br>0: No effect, 1: watchdog Interval Value reached interrupt enable. |
| 7:6          | /              | /               | /                                                                                                                |
| 5            | R/W            | 0x0             | TMR5_INT_EN.<br>Timer 5 Interrupt Enable.<br>0: No effect, 1: Timer 5 Interval Value reached interrupt enable.   |
| 4            | R/W            | 0x0             | TMR4_INT_EN.<br>Timer 4 Interrupt Enable.<br>0: No effect, 1: Timer 4 Interval Value reached interrupt enable.   |
| 3            | R/W            | 0x0             | TMR3_INT_EN.<br>Timer 3 Interrupt Enable.<br>0: No effect, 1: Timer 3 Interval Value reached interrupt enable.   |
| 2            | R/W            | 0x0             | TMR2_INT_EN.<br>Timer 2 Interrupt Enable.<br>0: No effect, 1: Timer 2 Interval Value reached interrupt enable.   |
| 1            | R/W            | 0x0             | TMR1_INT_EN.<br>Timer 1 Interrupt Enable.<br>0: No effect, 1: Timer 1 Interval Value reached interrupt enable.   |
| 0            | R/W            | 0x0             | TMR0_INT_EN.<br>Timer 0 Interrupt Enable.<br>0: No effect, 1: Timer 0 Interval Value reached interrupt enable.   |

### 11.3.2. ASYNC Timer IRQ Status Register(Default: 0x00000000)

| Offset: 0x04 |        |          | Register Name: ASYNC_TMR_IRQ_STAS_REG |
|--------------|--------|----------|---------------------------------------|
| Bit          | Read/W | Default/ | Description                           |

|      | rite | Hex |                                                                                                                                         |
|------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------|
| 31:9 | /    | /   | /                                                                                                                                       |
| 8    | R/W  | 0x0 | WDOG_IRQ_PEND.<br>Watchdog IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, Watchdog counter value is reached. |
| 7:6  | /    | /   | /                                                                                                                                       |
| 5    | R/W  | 0x0 | TMR5_IRQ_PEND.<br>Timer 5 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 5 counter value is reached.   |
| 4    | R/W  | 0x0 | TMR4_IRQ_PEND.<br>Timer 4 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 4 counter value is reached.   |
| 3    | R/W  | 0x0 | TMR3_IRQ_PEND.<br>Timer 3 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 3 counter value is reached.   |
| 2    | R/W  | 0x0 | TMR2_IRQ_PEND.<br>Timer 2 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 2 counter value is reached.   |
| 1    | R/W  | 0x0 | TMR1_IRQ_PEND.<br>Timer 1 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 1 interval value is reached.  |
| 0    | R/W  | 0x0 | TMR0_IRQ_PEND.<br>Timer 0 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending, timer 0 interval value is reached.  |

### 11.3.3. ASYNC Timer 0 Control Register (Default: 0x00000004)

| Offset: 0x10 |                |                 | Register Name: ASYNC_TMR0_CTRL_REG                                                                                                                                                                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                    |
| 31:8         | /              | /               | /                                                                                                                                                                                                                              |
| 7            | R/W            | 0x0             | TMR0_MODE.<br>Timer0 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically. |
| 6:4          | R/W            | 0x0             | TMR0_CLK_PRES<br>Select the pre-scale of timer 0 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16                                                                                                         |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 101: /32<br>110: /64<br>111: /128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3:2 | R/W | 0x1 | TMR0_CLK_SRC.<br>Timer 0 Clock Source.<br>00:/<br>01: OSC24M.<br>10: PLL6/6<br>11: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1   | R/W | 0x0 | TMR0_RELOAD.<br>Timer 0 Reload.<br>0: No effect, 1: Reload timer 0 Interval value.<br>After the bit is set, it can not be written again before it's cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | R/W | 0x0 | TMR0_EN.<br>Timer 0 Enable.<br>0: Stop/Pause, 1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

Note: Time between the timer disabled and enabled should be larger than 2\*Tcycles (Tcycles= Timer clock source/pre-scale).

#### 11.3.4. ASYNC Timer 0 Interval Value Register

| Offset: 0x14 |                |                 | Register Name: ASYNC_TMR0_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR0_INTV_VALUE.<br>Timer 0 Interval Value. |

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

#### 11.3.5. ASYNC Timer 0 Current Value Register

| Offset: 0x18 |                |                 | Register Name: ASYNC_TMR0_CURNT_VALUE_REG |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:0         | R/W            | 0x0             | TMR0_CUR_VALUE.<br>Timer 0 Current Value. |

Note: Timer 0 current value is a 32-bit down-counter (from interval value to 0). This register can be read correctly if the PCLK is faster than 2\*TimerFreq (TimerFreq = TimerClkSource/pre-scale).

### 11.3.6. ASYNC Timer 1 Control Register (Default: 0x00000004)

| Offset: 0x20 |                |                 | Register Name: ASYNC_TMR1_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:8         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7            | R/W            | 0x0             | TMR1_MODE.<br>Timer1 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically.                                                                                                                                                                    |
| 6:4          | R/W            | 0x0             | TMR1_CLK_PRES.<br>Select the pre-scale of timer 1 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                                                                                                                                                                                                                      |
| 3:2          | R/W            | 0x1             | TMR1_CLK_SRC.<br>Timer 1 Clock Source.<br>00:/<br>01: OSC24M.<br>10: PLL6/6<br>11: /                                                                                                                                                                                                                                                                                                              |
| 1            | R/W            | 0x0             | TMR1_RELOAD.<br>Timer 1 Reload.<br>0: No effect, 1: Reload timer 1 Interval value.<br>After the bit is set, it can not be written again before it's cleared automatically.                                                                                                                                                                                                                        |
| 0            | R/W            | 0x0             | TMR1_EN.<br>Timer 1 Enable.<br>0: Stop/Pause, 1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1. |

|  |  |  |                                                                                                                                                                                                                                                                      |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

Note: Time between the timer disabled and enabled should be larger than  $2^*T_{cycles}$  ( $T_{cycles} = \text{Timer clock source/pre-scale}$ ).

### 11.3.7. ASYNC Timer 1 Interval Value Register

| Offset: 0x24 |                |                 | Register Name: ASYNC_TMR1_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR1_INTV_VALUE.<br>Timer 1 Interval Value. |

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

### 11.3.8. ASYNC Timer 1 Current Value Register

| Offset: 0x28 |                |                 | Register Name: ASYNC_TMR1_CURNT_VALUE_REG |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:0         | R/W            | x               | TMR1_CUR_VALUE.<br>Timer 1 Current Value. |

Note: Timer 1 current value is a 32-bit down-counter (from interval value to 0). This register can be read correctly if the PCLK is faster than  $2^*\text{TimerFreq}$  ( $\text{TimerFreq} = \text{TimerClkSource/pre-scale}$ ).

### 11.3.9. ASYNC Timer 2 Control Register (Default: 0x00000004)

| Offset: 0x30 |                |                 | Register Name: ASYNC_TMR2_CTRL_REG                                                                                                                                                                                           |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                  |
| 31:8         | /              | /               | /                                                                                                                                                                                                                            |
| 7            | R/W            | 0x0             | TMR2_EN.<br>Timer2 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically. |
| 6:4          | R/W            | 0x0             | TMR2_CLK_PRESCALE.<br>Select the pre-scale of timer 2 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32                                                                                      |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 110: /64<br>111: /128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:2 | R/W | 0x1 | TMR2_CLK_SRC.<br>Timer 2 Clock Source.<br>00:/<br>01: OSC24M.<br>1x: /.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1   | R/W | 0x0 | TMR2_RELOAD.<br>Timer 2 Reload.<br>0: No effect, 1: Reload timer 2 Interval value.<br>After the bit is set, it can not be written again before it's cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | R/W | 0x0 | TMR2_EN.<br>Timer 2 Enable.<br>0: Stop/Pause, 1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

Note: Time between the timer disabled and enabled should be larger than 2\*Tcycles (Tcycles= Timer clock source/pre-scale).

### 11.3.10. ASYNC Timer 2 Interval Value Register

| Offset: 0x34 |                |                 | Register Name: ASYNC_TMR2_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR2_INTV_VALUE.<br>Timer 2 Interval Value. |

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

### 11.3.11. ASYNC Timer 2 Current Value Register

| Offset: 0x38 |                |                 | Register Name: ASYNC_TMR2_CURNT_VALUE_REG |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:0         | R/W            | x               | TMR2_CUR_VALUE.<br>Timer 2 Current Value. |

Note: Timer current value is a 32-bit down-counter (from interval value to 0). This register can be read correctly if the PCLK is faster than 2\*TimerFreq (TimerFreq = TimerClkSource/pre-scale).

### 11.3.12. ASYNC Timer 3 Control Register (Default: 0x00000000)

| Offset: 0x40 |                |                 | Register Name: ASYNC_TMR3_CTRL_REG                                                                                                                                                                                              |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                     |
| 31:8         | /              | /               | /                                                                                                                                                                                                                               |
| 7            | R/W            | 0x0             | TMR3_CLK_SRC.<br>Timer 3 Clock Source.<br>0:internal 32k<br>1: OSC24M.                                                                                                                                                          |
| 6:5          | /              | /               | /                                                                                                                                                                                                                               |
| 4            | R/W            | 0x0             | TMR3_MODE.<br>Timer 3 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically. |
| 3:2          | R/W            | 0x0             | TMR3_CLK_PRESCALE.<br>Select the pre-scale of timer 3 clock source.<br>00: /16<br>01: /32<br>10: /64<br>11: /1                                                                                                                  |
| 1            | /              | /               | /                                                                                                                                                                                                                               |
| 0            | R/W            | 0x0             | TMR3_EN.<br>Timer 3 Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                           |

Note: the time between the timer disabled and enabled should be larger than 2\*Tcycles (Tcycles= Timer clock source/pre-scale).

### 11.3.13. ASYNC Timer 3 Interval Value

| Offset: 0x44 |                |                 | Register Name: ASYNC_TMR3_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR3_INTV_VALUE.<br>Timer 3 Interval Value. |

### 11.3.14. ASYNC Timer 4 Control Register (Default: 0x00000004)

| Offset: 0x50 |                |                 | Register Name: ASYNC_TMR4_CTRL_REG |
|--------------|----------------|-----------------|------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                        |
| 31:8         | /              | /               | /                                  |
| 7            | R/W            | 0x0             | TMR4_MODE.                         |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | Timer4 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 6:4 | R/W | 0x0 | TMR4_CLK_PRESCALE.<br>Select the pre-scale of timer 4 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3:2 | R/W | 0x1 | TMR4_CLK_SRC.<br>Timer 4 Clock Source.<br>00: /<br>01: OSC24M.<br>10: External CLKIN0<br>11: /.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1   | R/W | 0x0 | TMR4_RELOAD.<br>Timer 4 Reload.<br>0: No effect, 1: Reload timer 0 Interval value.<br>After the bit is set, it can not be written again before it's cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0   | R/W | 0x0 | TMR4_EN.<br>Timer 4 Enable.<br>0: Stop/Pause, 1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

**Note:**

1. If the clock source is External CLKIN, the interval value register is not used, the current value register is an up counter that counting from 0.
2. The time between the timer disabled and enabled should be larger than  $2^*T_{cycles}$  ( $T_{cycles} = \text{Timer clock source/pre-scale}$ ).

### 11.3.15. ASYNC Timer 4 Interval Value Register

| Offset: 0x54 |                |                 | Register Name: ASYNC_TMR4_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR4_INTV_VALUE.<br>Timer 4 Interval Value. |

Note: the value setting should consider the system clock and the timer clock source.

### 11.3.16. ASYNC Timer 4 Current Value Register

| Offset: 0x58 |                |                 | Register Name: ASYNC_TMR4_CURNT_VALUE_REG |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:0         | R/W            | x               | TMR4_CUR_VALUE.<br>Timer 4 Current Value. |

Note:

1. Timer current value is a 32-bit down-counter (from interval value to 0). This register can be read correctly if the PCLK is faster than 2\*TimerFreq (TimerFreq = TimerClkSource/pre-scale).
2. Before the timer 4 is enabled, its current value register needs to be written with zero.

### 11.3.17. ASYNC Timer 5 Control Register (Default: 0x00000004)

| Offset: 0x60 |                |                 | Register Name: ASYNC_TMR5_CTRL_REG                                                                                                                                                                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                    |
| 31:8         | /              | /               | /                                                                                                                                                                                                                              |
| 7            | R/W            | 0x0             | TMR5_MODE.<br>Timer5 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically. |
| 6:4          | R/W            | 0x0             | TMR5_CLK_PRESCALE.<br>Select the pre-scale of timer 5 clock source.<br>000: /1<br>001: /2<br>010: /4<br>011: /8<br>100: /16<br>101: /32<br>110: /64<br>111: /128                                                               |
| 3:2          | R/W            | 0x1             | TMR5_CLK_SRC.<br>Timer 5 Clock Source.                                                                                                                                                                                         |

|   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 00: /<br>01: OSC24M.<br>10: External CLKIN1<br>11: /.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1 | R/W | 0x0 | TMR5_RELOAD.<br>Timer 5 Reload.<br>0: No effect, 1: Reload timer 0 Interval value.<br>After the bit is set, it can not be written again before it's cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 | R/W | 0x0 | TMR5_EN.<br>Timer 5 Enable.<br>0: Stop/Pause, 1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

Note:

1. If the clock source is External CLKIN, the interval value register is not used, the current value register is an up counter that counting from 0.
2. The time between the timer disabled and enabled should be larger than  $2^*T_{cycles}$  ( $T_{cycles} = \text{Timer clock source/pre-scale}$ ).

### 11.3.18. ASYNC Timer 5 Interval Value Register

| Offset: 0x64 |                |                 | Register Name: ASYNC_TMR5_INTV_VALUE_REG    |
|--------------|----------------|-----------------|---------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:0         | R/W            | x               | TMR5_INTV_VALUE.<br>Timer 5 Interval Value. |

Note: the value setting should consider the system clock and the timer clock source.

### 11.3.19. ASYNC Timer 5 Current Value Register

| Offset: 0x68 |                |                 | Register Name: ASYNC_TMR5_CURNT_VALUE_REG |
|--------------|----------------|-----------------|-------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:0         | R/W            | x               | TMR5_CUR_VALUE.<br>Timer 5 Current Value. |

Note:

1. Timer 1 current value is a 32-bit down-counter (from interval value to 0). This register can be read

correctly if the PCLK is faster than 2\*TimerFreq (TimerFreq = TimerClkSource/pre-scale).

2. Before timer 5 is enabled, its current value register needs to be written with zero.

### **11.3.20. AVS Counter Control Register (Default: 0x00000000)**

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

### **11.3.21. AVS Counter 0 Register (Default: 0x00000000)**

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

### 11.3.22. AVS Counter 1 Register (Default: 0x00000000)

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

### 11.3.23. AVS Counter Divisor Register (Default: 0x05DB05DB)

| Offset: 0x8C |             |         | Register Name: AVS_CNT_DIVISOR_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|-------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read /Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:28        | /           | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27:16        | R/W         | 0x5DB   | <p>AVS_CNT1_D</p> <p>Divisor N for AVS Counter1</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-bits counter engine will maintain another 12-bits counter. The 12-bits counter is used for counting the cycle number of one 24Mhz clock. When the 12-bits counter reaches (<math>\geq</math> N) the divisor value, the internal 33-bits counter register will increase 1 and the 12-bits counter will reset to zero and restart again.</p> <p>Notes: It can be configured by software at any time.</p> |
| 15:12        | /           | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11:0         | R/W         | 0x5DB   | <p>AVS_CNT0_D</p> <p>Divisor N for AVS Counter0</p> <p>The number N is from 1 to 0x7ff. The zero value is reserved.</p> <p>The internal 33-bits counter engine will maintain another 12-bits counter. The 12-bits counter is used for counting the cycle number of one 24Mhz clock. When the 12-bits counter reaches (<math>\geq</math> N) the divisor value, the internal 33-bits counter register will increase 1 and the 12-bits counter will reset to zero and restart again.</p> <p>Notes: It can be configured by software at any time.</p> |

### 11.3.24. Watchdog Control Register

| Offset: 0x90 |                |                 | Register Name: WDOG_CTRL_REG |
|--------------|----------------|-----------------|------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                  |

|       |     |       |                                                             |
|-------|-----|-------|-------------------------------------------------------------|
| 31:13 | /   | /     | /                                                           |
| 12:1  | R/W | 0x333 | KEY_FIELD.<br>/<br>WDOG_RESTART.                            |
| 0     | R/W | x     | Watchdog Restart.<br>0: No effect, 1: Restart the Watchdog. |

### 11.3.25. Watchdog Mode Register (Default: 0x00000000)

| Offset: 0x94 |                |                 | Register Name: WDOG_MODE_REG                                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                        |
| 31           | R/W            | 0               | WDOG_TEST_MODE.<br>0: normal mode, 1: test mode.                                                                                                                                                                                                                                                                                                                   |
| 30:7         | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                  |
| 6:3          | R/W            | 0x0             | WDOG_INTV_VALUE.<br>Watchdog Interval Value<br>Watchdog clock source is OSC24M. If the OSC24M is turned off, the watchdog will not work.<br>0000: 0.5sec<br>0001: 1sec<br>0010: 2sec<br>0011: 3sec<br>0100: 4sec<br>0101: 5sec<br>0110: 6sec<br>0111: 8sec<br>1000: 10sec<br>1001: 12sec<br>1010: 14sec<br>1011: 16sec<br>1100: /<br>1101: /<br>1110: /<br>1111: / |
| 2            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                  |
| 1            | R/W            | 0x0             | WDOG_RST_EN.<br>Watchdog Reset Enable.<br>0: No effect on the resets,<br>1: Enables the Watchdog to activate the system reset.                                                                                                                                                                                                                                     |
| 0            | R/W            | 0x0             | WDOG_EN.<br>Watchdog Enable.<br>0: No effect, 1: Enable the Watchdog.                                                                                                                                                                                                                                                                                              |

### 11.3.26. 64-bit Counter Low Register (Default: 0x00000000)

| Offset: 0xA4 |                |                 | Register Name: COUNTER64_LOW_REG     |
|--------------|----------------|-----------------|--------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                          |
| 31:0         | R/W            | 0x0             | CONT64_LO.<br>64-bit Counter [31:0]. |

### 11.3.27. 64-bit Counter High Register (Default: 0x00000000)

| Offset: 0xA8 |                |                 | Register Name: COUNTER64_HI_REG       |
|--------------|----------------|-----------------|---------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                           |
| 31:0         | R/W            | 0x0             | CONT64_HI.<br>64-bit Counter [63:32]. |

### 11.3.28. 64-bit Counter Control Register (Default: 0x00000000)

| Offset: 0xA0 |                |                 | Register Name: COUNTER64_CTRL_REG                                                                                                                                                          |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                |
| 31:3         | /              | /               | /                                                                                                                                                                                          |
| 2            | R/W            | 0x0             | CONT64_CLK_SRC_SEL.<br>64-bit Counter Clock Source Select.<br>0: OSC24M<br>1: PLL6/6                                                                                                       |
| 1            | R/W            | 0x0             | CONT64_RLATCH_EN.<br>64-bit Counter Read Latch Enable.<br>0: no effect, 1: to latch the 64-bit Counter to the Low/Hi registers and it will change to zero after the registers are latched. |
| 0            | R/W            | 0x0             | CONT64_CLR_EN.<br>64-bit Counter Clear Enable.<br>0: no effect, 1: to clear the 64-bit Counter Low/Hi registers and it will change to zero after the registers are cleared.                |

### 11.3.29. CPU Config Register (Default: 0x00000000)

| Offset: 0x13C |                |                 | Register Name: CPU_CFG_REG                                                                                                                                   |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                  |
| 31:2          | /              | /               | /                                                                                                                                                            |
| 1             | R/W            | 0x0             | L1_INVALID_RST_EN.<br>Enable L1 data cache invalidation at reset.<br>For L1 data cache, the cycles are up to 512 CPU clock cycles<br>0: enable<br>1: disable |
| 0             | R/W            | 0x0             | L2_INVALID_RST_EN.                                                                                                                                           |

|  |  |  |                                                                                                                                                   |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>Enable L2 data cache invalidation at reset.<br/>For L1 data cache, the cycles are up to 1024 CPU clock cycles<br/>0: enable<br/>1: disable</p> |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------|

Note: the bit [1:0] can be set to 0 by software.

## 12. Synchronic Timer

### 12.1. Overview

The chip implements 2 sync timers for high-speed counter.

### 12.2. Sync Timer Register List

| Module Name | Base Address |
|-------------|--------------|
| Sync Timer  | 0x01C60000   |

| Register Name          | Offset | Description                 |
|------------------------|--------|-----------------------------|
| SYNC_TMR IRQ_EN_REG    | 0x0000 | Timer IRQ Enable            |
| SYNC_TMR IRQ_STAS_REG  | 0x0004 | Timer Status                |
| SYNC_TMR0_CTRL_REG     | 0x0010 | Timer 0 Control             |
| SYNC_TMR0_INTV_LO_REG  | 0x0014 | Timer 0 Interval Value Low  |
| SYNC_TMR0_INTV_HI_REG  | 0x0018 | Timer 0 Interval Value High |
| SYNC_TMR0_CURNT_LO_REG | 0x001C | Timer 0 Current Value Low   |
| SYNC_TMR0_CURNT_HI_REG | 0x0020 | Timer 0 Current Value High  |
| SYNC_TMR1_CTRL_REG     | 0x0030 | Timer 1 Control             |
| SYNC_TMR1_INTV_LO_REG  | 0x0034 | Timer 1 Interval Value Low  |
| SYNC_TMR1_INTV_HI_REG  | 0x0038 | Timer 1 Interval Value High |
| SYNC_TMR1_CURNT_LO_REG | 0x003C | Timer 1 Current Value Low   |
| SYNC_TMR1_CURNT_HI_REG | 0x0040 | Timer 1 Current Value High  |

### 12.3. Sync Timer Register Description

#### 12.3.1. Sync Timer IRQ Enable Register (Default: 0x00000000)

| Offset: 0x00 |                |                 | Register Name: SYNC_TMR IRQ_EN_REG                                                                                     |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                            |
| 31:2         | /              | /               | /                                                                                                                      |
| 1            | R/W            | 0x0             | STMR1_INT_EN.<br>Sync Timer 1 Interrupt Enable.<br>0: No effect<br>1: Timer 1 Interval Value reached interrupt enable. |
| 0            | R/W            | 0x0             | STMR0_INT_EN.<br>Sync Timer 0 Interrupt Enable.<br>0: No effect<br>1: Timer 0 Interval Value reached interrupt enable. |

### 12.3.2. Sync Timer IRQ Status Register(Default: 0x00000000)

| Offset: 0x04 |                |                 | Register Name: SYNC_TMR_IRQ_STAS_REG                                                                                                           |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                    |
| 31:2         | /              | /               | /                                                                                                                                              |
| 1            | R/W            | 0x0             | STMR1_IRQ_PEND.<br>Sync Timer 1 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending, timer 1 interval value is reached. |
| 0            | R/W            | 0x0             | STMR0_IRQ_PEND.<br>Sync Timer 0 IRQ Pending. Set 1 to the bit will clear it.<br>0: No effect<br>1: Pending, timer 0 interval value is reached. |

### 12.3.3. Sync Timer 0 Control Register (Default: 0x00000004)

| Offset: 0x10 |                |                 | Register Name: SYNC_TMR0_CTRL_REG                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                      |
| 31           | R/W            | 0x0             | SYNC_TMR0_TEST.<br>Sync timer0 test mode. In test mode, the low register should be set to 0x1, the high register will down count. The counter needs to be reloaded.<br>0: normal mode<br>1: test mode.                                                                           |
| 30:8         | /              | /               | /                                                                                                                                                                                                                                                                                |
| 7            | R/W            | 0x0             | STMR0_MODE.<br>Sync Timer0 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically.<br>Timer 0 Clock Source is fixed to AHBCLK. |
| 6:4          | R/W            | 0x0             | STMR0_CLK_<br>Select the pre-scale of the sync timer 0 clock source.<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/W | 0x0 | STMR0_RELOAD.<br>Sync Timer 0 Reload.<br>0: No effect, 1: Reload timer 0 Interval value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0 | R/W | 0x0 | STMR0_EN.<br>Sync Timer 0 Enable.<br>0: Stop/Pause<br>1: Start.<br>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.<br>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.<br>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time. |

#### 12.3.4. Sync Timer 0 Interval Value Low Register

| Offset: 0x14 |                |                 | Register Name: SYNC_TMR0_INTV_LO_REG                        |
|--------------|----------------|-----------------|-------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                 |
| 31:0         | R/W            | x               | STMR0_INTV_VALUE_LO.<br>Sync Timer 0 Interval Value [31:0]. |

#### 12.3.5. Sync Timer 0 Interval Value High Register

| Offset: 0x18 |                |                 | Register Name: SYNC_TMR0_INTV_HI_REG                         |
|--------------|----------------|-----------------|--------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31:24        | /              | /               | /                                                            |
| 23:0         | R/W            | x               | STMR0_INTV_VALUE_HI.<br>Sync Timer 0 Interval Value [55:32]. |

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

#### 12.3.6. Sync Timer 0 Current Value Lo Register

| Offset: 0x1C |                |                 | Register Name: SYNC_TMR0_CURNT_LOW_REG                     |
|--------------|----------------|-----------------|------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                |
| 31:0         | R/W            | x               | STMR0_CUR_VALUE_LOW.<br>Sync Timer 0 Current Value [31:0]. |

#### 12.3.7. Sync Timer 0 Current Value Hi Register

|              |                                       |
|--------------|---------------------------------------|
| Offset: 0x20 | Register Name: SYNC_TMR0_CURNT_HI_REG |
|--------------|---------------------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                |
|-------|----------------|-----------------|------------------------------------------------------------|
| 31:24 | /              | /               | /                                                          |
| 23:0  | R/W            | x               | STMR0_CUR_VALUE_HI.<br>Sync Timer 0 Current Value [55:32]. |

Note:

1. Timer 0 current value is a 56-bit down-counter (from interval value to 0).
2. The current value register is a 56-bit register. When read or write the current value, the Low register should be read or write first.

#### 12.3.8. Sync Timer 1 Control Register (Default: 0x00000004)

| Offset: 0x30 |                |                 | Register Name: SYNC_TMR1_CTRL_REG                                                                                                                                                                                                                                                            |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                  |
| 31           | R/W            | 0x0             | <b>SYNC_TMR1_TEST.</b><br>Sync timer1 test mode. In test mode, the low register should be set to 0x1, the high register will down count. The counter needs to be reloaded.<br>0: normal mode, 1: test mode.                                                                                  |
| 30:8         | /              | /               | /                                                                                                                                                                                                                                                                                            |
| 7            | R/W            | 0x0             | <b>STMR1_MODE.</b><br>Sync Timer1 mode.<br>0: Continuous mode. When reaches the internal value, the timer will not be disabled automatically.<br>1: Single mode. When reaches the internal value, the timer will be disabled automatically.<br>Sync Timer 1 Clock Source is fixed to AHBCLK. |
| 6:4          | R/W            | 0x0             | <b>STMR1_CLK_SRC.</b><br>Select the pre-scale of the sync timer 1 clock source.<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/W            | 0x0             | <b>STMR1_RELOAD.</b><br>Sync Timer 1 Reload.<br>0: No effect, 1: Reload timer 1 Interval value.                                                                                                                                                                                              |
| 0            | R/W            | 0x0             | <b>STMR1_EN.</b><br>Sync Timer 1 Enable.                                                                                                                                                                                                                                                     |

|  |  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>0: Stop/Pause, 1: Start.</p> <p>If the timer is started, it will reload the interval value to internal register, and the current counter will count from interval value to 0.</p> <p>If the current counter does not reach the zero, the timer enable bit is set to "0"; the current value counter will pause. At least wait for 2 Tcycles, the start bit can be set to 1.</p> <p>In timer pause state, the interval value register can be modified. If the timer is started again, and the Software hope the current value register to down-count from the new interval value, the reload bit and the enable bit should be set to 1 at the same time.</p> |
|--|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 12.3.9. Sync Timer 1 Interval Value Low Register

| Offset: 0x34 |                |                 | Register Name: SYNC_TMR1_INTV_LOW_REG                        |
|--------------|----------------|-----------------|--------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31:0         | R/W            | x               | STMR1_INTV_VALUE_LOW.<br>Sync Timer 1 Interval Value [31:0]. |

### 12.3.10. Sync Timer 1 Interval Value High Register

| Offset: 0x38 |                |                 | Register Name: SYNC_TMR1_INTV_HI_REG                         |
|--------------|----------------|-----------------|--------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31:24        | /              | /               | /                                                            |
| 23:0         | R/W            | x               | STMR1_INTV_VALUE_HI.<br>Sync Timer 1 Interval Value [55:32]. |

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

### 12.3.11. Sync Timer 1 Current Value Low Register

| Offset: 0x3C |                |                 | Register Name: SYNC_TMR1_CURNT_LOW_REG                     |
|--------------|----------------|-----------------|------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                |
| 31:0         | R/W            | x               | STMR1_CUR_VALUE_LOW.<br>Sync Timer 1 Current Value [31:0]. |

### 12.3.12. Sync Timer 1 Current Value High Register

| Offset: 0x40 |                |                 | Register Name: SYNC_TMR1_CURNT_HI_REG                      |
|--------------|----------------|-----------------|------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                |
| 31:24        | /              | /               | /                                                          |
| 23:0         | R/W            | x               | STMR1_CUR_VALUE_HI.<br>Sync Timer 1 Current Value [55:32]. |

Note:

A10s User Manual V1.40

Copyright © 2015 Allwinner Technology. All Rights Reserved.  
2015.04.22

1. Timer 0 current value is a 56-bit down-counter (from interval value to 0).
2. The current value register is a 56-bit register. When read or write the current value, the Low register should be read or written first.

# 13. Interrupt Controller

## 13.1. Overview

The interrupt controller features:

- Control the nIRQ and FIQ of a RISC Processor
- Up to 96 interrupt sources
- 4-Level Priority Controller
- External Sources of Edge-sensitive or Level-sensitive

Since the 4-level Priority Controller allows users to define the priority of each interrupt source, so higher priority interrupts can be serviced even if a lower priority interrupt is being treated.

## 13.2. Interrupt Source

The interrupt source 0 is always located at FIQ. The interrupt sources 1 to 63 are located at System Interrupt and user peripheral.

| Interrupt Source | SRC | Vector | FIQ | Description                                                                                      |
|------------------|-----|--------|-----|--------------------------------------------------------------------------------------------------|
| External NMI     | 0   | 0x0000 | YES | External Non-Mask Interrupt.<br>Power module<br>battery/VDD/VDDIO/VDD18/VDD25 brownout<br>detect |
| UART 0           | 1   | 0x0004 |     | UART 0 interrupt                                                                                 |
| UART 1           | 2   | 0x0008 |     | UART 1 interrupt                                                                                 |
| UART 2           | 3   | 0x000C |     | UART 2 interrupt                                                                                 |
| UART 3           | 4   | 0x0010 |     | UART 3 interrupt                                                                                 |
| IR               | 5   | 0x0014 |     | IR 0 interrupt                                                                                   |
| /                | 6   | 0x0018 |     | /                                                                                                |
| TWI 0            | 7   | 0x001C |     | TWI 0 interrupt                                                                                  |
| TWI 1            | 8   | 0x0020 |     | TWI 1 interrupt                                                                                  |
| TWI 2            | 9   | 0x0024 |     | TWI 2 interrupt                                                                                  |
| SPI 0            | 10  | 0x0028 |     | SPI 0 interrupt                                                                                  |
| SPI 1            | 11  | 0x002C |     | SPI 1 interrupt                                                                                  |
| SPI 2            | 12  | 0x0030 |     | SPI 2 interrupt                                                                                  |
| /                | 13  | 0x0034 |     | /                                                                                                |
| /                | 14  | 0x0038 |     | /                                                                                                |
| TS               | 15  | 0x003C |     | TS interrupt                                                                                     |
| IIS              | 16  | 0x0040 |     | Digital Audio Controller interrupt                                                               |
| /                | 17  | 0x0044 |     | /                                                                                                |
| /                | 18  | 0x0048 |     | /                                                                                                |
| /                | 19  | 0x004C |     | /                                                                                                |
| /                | 20  | 0x0050 |     | /                                                                                                |
| Keypad           | 21  | 0x0054 |     | Keypad interrupt                                                                                 |

| Interrupt Source | SRC | Vector | FIQ | Description                                    |
|------------------|-----|--------|-----|------------------------------------------------|
| Timer 0          | 22  | 0x0058 |     | Timer port 0                                   |
| Timer 1          | 23  | 0x005C |     | Timer port 1                                   |
| Timer 2/Alarm/WD | 24  | 0x0060 |     | Timer 2 , Alarm, Watchdog                      |
| Timer 3          | 25  | 0x0064 |     | Timer 3 interrupt                              |
| /                | 26  | 0x0068 |     | /                                              |
| DMA              | 27  | 0x006C |     | DMA channel interrupt                          |
| PIO              | 28  | 0x0070 |     | PIO interrupt                                  |
| Touch Panel.     | 29  | 0x0074 |     | Touch Panel interrupt.                         |
| Audio Codec      | 30  | 0x0078 |     | Analog Audio Codec interrupt                   |
| LRADC            | 31  | 0x007C |     | LRADC interrupt                                |
| SD/MMC 0         | 32  | 0x0080 |     | SD/MMC Host Controller 0 interrupt             |
| SD/MMC 1         | 33  | 0x0084 |     | SD/MMC Host Controller 1 interrupt             |
| SD/MMC 2         | 34  | 0x0088 |     | SD/MMC Host Controller 2 interrupt             |
| /                | 35  | 0x008C |     | /                                              |
| /                | 36  | 0x0090 |     | /                                              |
| NAND             | 37  | 0x0094 |     | NAND Flash Controller (NFC) interrupt          |
| USB-DRD          | 38  | 0x0098 |     | USB DRD wakeup, connect, disconnect interrupt  |
| USB-EHCI         | 39  | 0x009C |     | USB EHCI wakeup, connect, disconnect interrupt |
| USB-OHCI         | 40  | 0x00A0 |     | USB OHCI wakeup, connect, disconnect interrupt |
| /                | 41  | 0x00A4 |     | /                                              |
| CSI              | 42  | 0x00A8 |     | CSI interrupt                                  |
| /                | 43  | 0x00AC |     | /                                              |
| LCD Controller   | 44  | 0x00B0 |     | LCD Controller interrupt                       |
| /                | 45  | 0x00B4 |     | /                                              |
| /                | 46  | 0x00B8 |     | /                                              |
| DE-FE/DE-BE      | 47  | 0x00BC |     | DE-FE/DE-BE interrupt                          |
| /                | 48  | 0x00C0 |     | /                                              |
| PMU              | 49  | 0x00C4 |     | PMU interrupt                                  |
| /                | 50  | 0x00C8 |     | /                                              |
| /                | 51  | 0x00CC |     | /                                              |
| /                | 52  | 0x00D0 |     | /                                              |
| VE               | 53  | 0x00D4 |     | VE interrupt                                   |
| SS               | 54  | 0x00D8 |     | Security System interrupt                      |
| EMAC             | 55  | 0x00DC |     | EMAC interrupt                                 |
| /                | 56  | 0x00E0 |     | /                                              |
| GPS              | 57  | 0x00E4 |     | GPS interrupt                                  |
| HDMI             | 58  | 0x00E8 |     | HDMI interrupt                                 |
| TVE 0/1          | 59  | 0x00EC |     | TV encoder 0/1 interrupt                       |

| Interrupt Source | SRC | Vector | FIQ | Description                                                                                                                       |
|------------------|-----|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| /                | 60  | 0x00F0 |     | /                                                                                                                                 |
| /                | 61  | 0x00F4 |     | /                                                                                                                                 |
| /                | 62  | 0x00F8 |     | /                                                                                                                                 |
| /                | 63  | 0x00FC |     | /                                                                                                                                 |
| /                | 64  | 0x100  |     | /                                                                                                                                 |
| /                | 65  | 0x104  |     | /                                                                                                                                 |
| PLE/PERFMU       | 66  | 0x108  |     | PLE on non-secure transfers interrupt<br>PLE on secure transfer interrupt<br>PLE error interrupt<br>Performance monitor interrupt |
| Timer 4          | 67  | 0x010C |     | Timer 4 interrupt                                                                                                                 |
| Timer 5          | 68  | 0x0110 |     | Timer 5 interrupt                                                                                                                 |
| GPU-GP           | 69  | 0x0114 |     |                                                                                                                                   |
| GPU-GPMMU        | 70  | 0x0118 |     |                                                                                                                                   |
| GPU-PP0          | 71  | 0x011C |     |                                                                                                                                   |
| GPU-PPMMU0       | 72  | 0x0120 |     |                                                                                                                                   |
| GPU-PMU          | 73  | 0x0124 |     |                                                                                                                                   |
| GPU-RSV0         | 74  | 0x0128 |     |                                                                                                                                   |
| GPU-RSV1         | 75  | 0x012C |     |                                                                                                                                   |
| GPU-RSV2         | 76  | 0x0130 |     |                                                                                                                                   |
| GPU-RSV3         | 77  | 0x0134 |     |                                                                                                                                   |
| GPU-RSV4         | 78  | 0x0138 |     |                                                                                                                                   |
| GPU-RSV5         | 79  | 0x013C |     |                                                                                                                                   |
| GPU-RSV6         | 80  | 0x0140 |     |                                                                                                                                   |
| /                | 81  | 0x0144 |     |                                                                                                                                   |
| Sync timer 0     | 82  | 0x0148 |     |                                                                                                                                   |
| Sync timer 1     | 83  | 0x014C |     |                                                                                                                                   |

### 13.3. Interrupt Register List

| Module Name | Base Address |
|-------------|--------------|
| INTC        | 0x01C20400   |

| Register Name      | Offset | Description                    |
|--------------------|--------|--------------------------------|
| INTC_VECTOR_REG    | 0x0000 | Interrupt Vector               |
| INTC_BASE_ADDR_REG | 0x0004 | Interrupt Base Address         |
| INC_PROTEC_REG     | 0x0008 | Interrupt Protection           |
| INTC_NMII_CTRL_REG | 0x000C | Interrupt Control              |
| INTC_IRQ_PEND_REG0 | 0x0010 | Interrupt IRQ Pending 0 Status |
| INTC_IRQ_PEND_REG1 | 0x0014 | Interrupt IRQ Pending 1 Status |

|                    |        |                                |
|--------------------|--------|--------------------------------|
| INTC_IRQ_PEND_REG2 | 0x0018 | Interrupt IRQ Pending 2 Status |
| /                  | 0x001C | /                              |
| INTC_FIQ_PEND_REG0 | 0x0020 | Interrupt FIQ Pending 0 Status |
| INTC_FIQ_PEND_REG1 | 0x0024 | Interrupt FIQ Pending 1 Status |
| INTC_FIQ_PEND_REG2 | 0x0028 | Interrupt FIQ Pending 2 Status |
| /                  | 0x002C | /                              |
| INTC_SEL_REG0      | 0x0030 | Interrupt Select 0             |
| INTC_SEL_REG1      | 0x0034 | Interrupt Select 1             |
| INTC_SEL_REG2      | 0x0038 | Interrupt Select 2             |
| /                  | 0x003C | /                              |
| INTC_EN_REG0       | 0x0040 | Interrupt Enable 0             |
| INTC_EN_REG1       | 0x0044 | Interrupt Enable 1             |
| INTC_EN_REG2       | 0x0048 | Interrupt Enable 2             |
| /                  | 0x004C | /                              |
| INTC_MASK_REG0     | 0x0050 | Interrupt Mask 0               |
| INTC_MASK_REG1     | 0x0054 | Interrupt Mask 1               |
| INTC_MASK_REG2     | 0x0058 | Interrupt Mask 2               |
| /                  | 0x005C | /                              |
| INTC_RESP_REG0     | 0x0060 | Interrupt Response 0           |
| INTC_RESP_REG1     | 0x0064 | Interrupt Response 1           |
| INTC_RESP_REG2     | 0x0068 | Interrupt Response 2           |
| /                  | 0x006C | /                              |
| INTC_FORCE_REG0    | 0x0070 | Interrupt Fast Forcing 0       |
| INTC_FORCE_REG1    | 0x0074 | Interrupt Fast Forcing 1       |
| INTC_FORCE_REG2    | 0x0078 | Interrupt Fast Forcing 2       |
| /                  | 0x007C | /                              |
| INTC_SRC_PRIO_REG0 | 0x0080 | Interrupt Source Priority 0    |
| INTC_SRC_PRIO_REG1 | 0x0084 | Interrupt Source Priority 1    |
| INTC_SRC_PRIO_REG2 | 0x0088 | Interrupt Source Priority 2    |
| INTC_SRC_PRIO_REG3 | 0x008C | Interrupt Source Priority 3    |
| INTC_SRC_PRIO_REG4 | 0x0090 | Interrupt Source Priority 4    |
| INTC_SRC_PRIO_REG5 | 0x0094 | Interrupt Source Priority 5    |

## 13.4. Interrupt Register Description

### 13.4.1. Interrupt Vector Register (Default: 0x00000000)

| Offset:0x00 |                |                 | Register Name: INTC_VECTOR_REG                                                                                    |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                       |
| 31:2        | R              | 0x0             | VECTOR_ADDR.<br>This register present the vector address for the interrupt currently active on the CPU IRQ input. |

|     |   |     |                                            |
|-----|---|-----|--------------------------------------------|
| 1:0 | R | 0x0 | ZERO.<br>Always return zero to this field. |
|-----|---|-----|--------------------------------------------|

#### 13.4.2. Interrupt Base Address Register (Default: 0x00000000)

| Offset:0x04 |                |                 | Register Name: INTC_BASE_ADDR_REG                                                             |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                   |
| 31:2        | R/W            | 0x0             | BASE_ADDR.<br>This bit-field holds the upper 30 bits of the base address of the vector table. |
| 1:0         | R              | 0x0             | ZERO.<br>Always write zero to this bit-field.                                                 |

#### 13.4.3. Interrupt Protection Register (Default: 0x00000000)

| Offset:0x08 |                |                 | Register Name: INC_PROTEC_REG                                                                                                                                                                                                                                                                                                                             |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                               |
| 31:1        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                         |
| 0           | R/W            | 0x0             | PROTECT_EN.<br>Enables or disables protected register access:<br>0: disable protection mode<br>1: enable protection mode<br>If enabled, only privileged mode access can access the interrupt controller registers.<br>If disabled, both user mode and privileged mode can access the registers.<br>This register can only be accessed in privileged mode. |

#### 13.4.4. NMI Interrupt Control Register (Default: 0x00000000)

| Offset:0x0C |                |                 | Register Name: INTC_NMII_CTRL_REG                                                                                                                                             |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                   |
| 31:2        | /              | /               | /                                                                                                                                                                             |
| 1:0         | R/W            | 0x0             | NMI_SRC_TYPE.<br>External NMI Interrupt Source Type.<br>00 : Low level sensitive<br>01 : Negative edge triggered<br>10 : High level sensitive<br>11 : Positive edge sensitive |

#### 13.4.5. Interrupt IRQ Pending Register 0(Default: 0x00000000)

| Offset:0x10 |        |          | Register Name: INTC_IRQ_PEND_REG0 |
|-------------|--------|----------|-----------------------------------|
| Bit         | Read/W | Default/ | Description                       |

|      | rite | Hex |                                                                                                                                                             |
|------|------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R    | 0x0 | INT_IRQ_SRC_PEND0.<br>Interrupt IRQ Source [31:0] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### 13.4.6. Interrupt IRQ Pending Register 1(Default: 0x00000000)

| Offset:0x14 |                |                 | Register Name: INTC_PEND_REG1                                                                                                                                |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                  |
| 31:0        | R              | 0x0             | INT_IRQ_SRC_PEND1.<br>Interrupt IRQ Source [63:32] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### 13.4.7. Interrupt IRQ Pending Register 2(Default: 0x00000000)

| Offset:0x18 |                |                 | Register Name: INTC_PEND_REG2                                                                                                                                |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                  |
| 31:0        | R              | 0x0             | INT_IRQ_SRC_PEND2.<br>Interrupt IRQ Source [95:64] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### 13.4.8. Interrupt FIQ Pending/Clear Register 0 (Default: 0x00000000)

| Offset:0x20 |                |                 | Register Name: INTC_FIQ_PEND_REG0                                                                                                                           |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                 |
| 31:0        | R              | 0x0             | INT_FIQ_SRC_PEND0.<br>Interrupt FIQ Source [31:0] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### 13.4.9. Interrupt FIQ Pending/Clear Register 1(Default: 0x00000000)

| Offset:0x24 |                |                 | Register Name: INTC_FIQ_PEND_REG1                                                                                                                        |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                              |
| 31:0        | R              | 0x0             | INT_FIQ_SRC_PEND1.<br>Interrupt Source [63:32] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### **13.4.10. Interrupt FIQ Pending/Clear Register 2(Default: 0x00000000)**

| Offset:0x28 |                |                 | Register Name: INTC_FIQ_PEND_REG2                                                                                                                        |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                              |
| 31:0        | R              | 0x0             | INT_FIQ_SRC_PEND2.<br>Interrupt Source [95:64] Pending/Clear Bit.<br>0: Corresponding interrupt is not pending.<br>1: Corresponding interrupt is pending |

#### **13.4.11. Interrupt Select Register 0(Default: 0x00000000)**

| Offset:0x30 |                |                 | Register Name: INTC_SEL_REG0                                                   |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:0        | R/W            | 0x0             | INT_SRC_TYPE0<br>Interrupt Source [31:0] irq type select.<br>0: IRQ.<br>1: FIQ |

#### **13.4.12. Interrupt Select Register 1(Default: 0x00000000)**

| Offset:0x34 |                |                 | Register Name: INTC_SEL_REG1                                                     |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                      |
| 31:0        | R/W            | 0x0             | INT_SRC_TYPE1.<br>Interrupt Source [63:32] irq type select.<br>0: IRQ.<br>1: FIQ |

#### **13.4.13. Interrupt Select Register 2(Default: 0x00000000)**

| Offset:0x38 |                |                 | Register Name: INTC_SEL_REG2                                                     |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                      |
| 31:0        | R/W            | 0x0             | INT_SRC_TYPE2.<br>Interrupt Source [95:64] irq type select.<br>0: IRQ.<br>1: FIQ |

#### **13.4.14. Interrupt Enable Register 0(Default: 0x00000000)**

| Offset:0x40 |                |                 | Register Name: INTC_EN_REG0                                                                     |
|-------------|----------------|-----------------|-------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                     |
| 31:0        | R/W            | 0x0             | INT_SRC_EN0.<br>Interrupt Source [31:0] Enable Bits.<br>0: Corresponding interrupt is disabled. |

|  |  |  |                                        |
|--|--|--|----------------------------------------|
|  |  |  | 1: Corresponding interrupt is enabled. |
|--|--|--|----------------------------------------|

#### 13.4.15. Interrupt Enable Register 1(Default: 0x00000000)

| Offset:0x44 |                |                 | Register Name: INTC_EN_REG1                                                                                                                |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:0        | R/W            | 0x0             | INT_SRC_EN1.<br>Interrupt Source [63:32] Enable Bits.<br>0: Corresponding interrupt is disabled.<br>1: Corresponding interrupt is enabled. |

#### 13.4.16. Interrupt Enable Register 2(Default: 0x00000000)

| Offset:0x48 |                |                 | Register Name: INTC_EN_REG2                                                                                                                |
|-------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                |
| 31:0        | R/W            | 0x0             | INT_SRC_EN2.<br>Interrupt Source [95:64] Enable Bits.<br>0: Corresponding interrupt is disabled.<br>1: Corresponding interrupt is enabled. |

#### 13.4.17. Interrupt Mask Register 0(Default: 0x00000000)

| Offset:0x50 |                |                 | Register Name: INTC_MASK_REG0                                                                                                                                                                                                                      |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                        |
| 31:0        | R/W            | 0x0             | INT_MASK0.<br>Interrupt Source [31:0] Mask Bits.<br>0: No effect.<br>1: interrupt is masked.<br><br>If interrupt is enabled and the interrupt occurred, the interrupt pending bit will be set whether the corresponding interrupt mask bit is set. |

#### 13.4.18. Interrupt Mask Register 1(Default: 0x00000000)

| Offset:0x54 |                |                 | Register Name: INTC_MASK_REG1                                                                                                                                                                                                                       |
|-------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                         |
| 31:0        | R/W            | 0x0             | INT_MASK1.<br>Interrupt Source [63:32] Mask Bits.<br>0: No effect.<br>1: interrupt is masked.<br><br>If interrupt is enabled and the interrupt occurred, the interrupt pending bit will be set whether the corresponding interrupt mask bit is set. |

#### **13.4.19. Interrupt Mask Register 2(Default: 0x00000000)**

| Offset:0x58 |                |                 | Register Name: INTC_MASK_REG2                                                                                                                                                                                                                                          |
|-------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                            |
| 31:0        | R/W            | 0x0             | <p>INT_MASK2.</p> <p>Interrupt Source [95:64] Mask Bits.</p> <p>0: No effect.</p> <p>1: interrupt is masked.</p> <p>If interrupt is enabled and the interrupt occurred, the interrupt pending bit will be set whether the corresponding interrupt mask bit is set.</p> |

#### **13.4.20. Interrupt Response Register 0(Default: 0x00000000)**

| Offset:0x60 |                |                 | Register Name: INTC_RESP_REG0                                                                                                                                             |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                               |
| 31:0        | R/W            | 0x0             | <p>INT_RESP0.</p> <p>Interrupt Source [31:0] response bit.</p> <p>If the corresponding bit is set, the interrupt with the lower or the same priority level is masked.</p> |

#### **13.4.21. Interrupt Response Register 1(Default: 0x00000000)**

| Offset:0x64 |                |                 | Register Name: INTC_RESP_REG1                                                                                                                                              |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                |
| 31:0        | R/W            | 0x0             | <p>INT_RESP1.</p> <p>Interrupt Source [63:32] response bit.</p> <p>If the corresponding bit is set, the interrupt with the lower or the same priority level is masked.</p> |

#### **13.4.22. Interrupt Response Register 2(Default: 0x00000000)**

| Offset:0x68 |                |                 | Register Name: INTC_RESP_REG2                                                                                                                                              |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                |
| 31:0        | R/W            | 0x0             | <p>INT_RESP2.</p> <p>Interrupt Source [95:64] response bit.</p> <p>If the corresponding bit is set, the interrupt with the lower or the same priority level is masked.</p> |

#### **13.4.23. Interrupt Fast Forcing Register 0(Default: 0x00000000)**

| Offset:0x70 |                |                 | Register Name: INTC_FORCE_REG0 |
|-------------|----------------|-----------------|--------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                    |
| 31:0        | W              | 0x0             | INT_FF0                        |

|  |  |  |                                                                                                                                                                                                                                      |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | Enables the fast forcing feature on the corresponding interrupt source [31:0].<br>0: No effect.<br>1: Forcing the corresponding interrupt.<br>Setting this bit can be valid only when the corresponding interrupt enable bit is set. |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 13.4.24. Interrupt Fast Forcing Register 1(Default: 0x00000000)

| Offset:0x74 |                |                 | Register Name: INTC_FORCE_REG1                                                                                                                                                                                                                    |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                       |
| 31:0        | W              | 0x0             | INT_FF1.<br>Enables the fast forcing feature on the corresponding interrupt source [63:32].<br>0: No effect.<br>1: Forcing the corresponding interrupt.<br>Setting this bit can be valid only when the corresponding interrupt enable bit is set. |

#### 13.4.25. Interrupt Fast Forcing Register 2(Default: 0x00000000)

| Offset:0x78 |                |                 | Register Name: INTC_FORCE_REG2                                                                                                                                                                                                                    |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                       |
| 31:0        | W              | 0x0             | INT_FF2.<br>Enables the fast forcing feature on the corresponding interrupt source [95:64].<br>0: No effect.<br>1: Forcing the corresponding interrupt.<br>Setting this bit can be valid only when the corresponding interrupt enable bit is set. |

#### 13.4.26. Interrupt Source Priority 0 Register (Default: 0x00000000)

| Offset:0x80 |                |                 | Register Name: INTC_SRC_PRIO_REG0                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 31:30       | R/W            | 0x0             | IRQ15_PRIO.<br>IRQ 15 Priority.<br>Set priority level for IRQ bit 15<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority |
| 29:28       | R/W            | 0x0             | IRQ14_PRIO.                                                                                                                                                                                             |

| Offset:0x80 |     |     | Register Name: INTC_SRC_PRIO_REG0                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | IRQ 14 Priority.<br>Set priority level for IRQ bit 14<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority                |
| 27:26       | R/W | 0x0 | IRQ13_PRIO.<br>IRQ 13 Priority.<br>Set priority level for IRQ bit 13<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority |
| 25:24       | R/W | 0x0 | IRQ12_PRIO.<br>IRQ 12 Priority.<br>Set priority level for IRQ bit 12<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority |
| 23:22       | R/W | 0x0 | IRQ11_PRIO.<br>IRQ 11 Priority.<br>Set priority level for IRQ bit 11<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority |
| 21:20       | R/W | 0x0 | IRQ10_PRIO.<br>IRQ 10 Priority.<br>Set priority level for IRQ bit 10<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority |
| 19:18       | R/W | 0x0 | IRQ9_PRIO.<br>IRQ 9 Priority.<br>Set priority level for IRQ bit 9<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x2 level 2<br>Level3 = 0x3 level 3, highest priority    |
| 17:16       | R/W | 0x0 | IRQ8_PRIO.                                                                                                                                                                                              |

| Offset:0x80 |     |     | Register Name: INTC_SRC_PRIO_REG0                                                                                                                                                                                       |
|-------------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | <p>IRQ 8 Priority.<br/> Set priority level for IRQ bit 8<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x2 level 2<br/> Level3 = 0x3 level 3, highest priority</p>                 |
| 15:14       | R/W | 0x0 | <p>IRQ7_PRIO.<br/> IRQ 7 Priority.<br/> Set priority level for IRQ bit 7<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x2 level 2<br/> Level3 = 0x3 level 3, highest priority</p> |
| 13:12       | R/W | 0x0 | <p>IRQ6_PRIO.<br/> IRQ 6 Priority.<br/> Set priority level for IRQ bit 6<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x2 level 2<br/> Level3 = 0x3 level 3, highest priority</p> |
| 11:10       | R/W | 0x0 | <p>IRQ5_PRIO.<br/> IRQ 5 Priority.<br/> Set priority level for IRQ bit 5<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x2 level 2<br/> Level3 = 0x3 level 3, highest priority</p> |
| 9:8         | R/W | 0x0 | <p>IRQ4_PRIO.<br/> IRQ 4 Priority.<br/> Set priority level for IRQ 4<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x2 level 2<br/> Level3 = 0x3 level 3, highest priority</p>     |
| 7:6         | R/W | 0x0 | <p>IRQ3_PRIO.<br/> IRQ 3 Priority.<br/> Set priority level for IRQ bit 3<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x1 level 2<br/> Level3 = 0x1 level 3, highest priority</p> |
| 5:4         | R/W | 0x0 | IRQ2_PRIO.                                                                                                                                                                                                              |

|             |     |     |                                                                                                                                                                                                      |
|-------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset:0x80 |     |     | Register Name: INTC_SRC_PRIO_REG0                                                                                                                                                                    |
|             |     |     | IRQ 2 Priority.<br>Set priority level for IRQ bit 2<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority               |
| 3:2         | R/W | 0x0 | IRQ1_PRIO.<br>IRQ 1 Priority.<br>Set priority level for IRQ bit 1<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 1:0         | /   | /   | /                                                                                                                                                                                                    |

Programs the priority level for all sources except FIQ source (source 0).The priority level ranges from 0(lowest) to 7(highest).

#### 13.4.27. Interrupt Source Priority 1 Register (Default: 0x00000000)

| Offset:0x84 |                |                 | Register Name: INTC_SRC_PRIO_REG1                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 31:30       | R/W            | 0x0             | IRQ31_PRIO.<br>IRQ 31 Priority.<br>Set priority level for IRQ bit 31<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 29:28       | R/W            | 0x0             | IRQ30_PRIO.<br>IRQ 30 Priority.<br>Set priority level for IRQ bit 30<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 27:26       | R/W            | 0x0             | IRQ29_PRIO.<br>IRQ 29 Priority.<br>Set priority level for IRQ bit 29<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

| Offset:0x84 |     |     | Register Name: INTC_SRC_PRIO_REG1                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24       | R/W | 0x0 | IRQ28_PRIO.<br>IRQ 28 Priority.<br>Set priority level for IRQ bit 28<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 23:22       | R/W | 0x0 | IRQ27_PRIO.<br>IRQ 27 Priority.<br>Set priority level for IRQ bit 27<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 21:20       | R/W | 0x0 | IRQ26_PRIO.<br>IRQ 26 Priority.<br>Set priority level for IRQ bit 26<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 19:18       | R/W | 0x0 | IRQ25_PRIO.<br>IRQ 25 Priority.<br>Set priority level for IRQ bit 25<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 17:16       | R/W | 0x0 | IRQ24_PRIO.<br>IRQ 24 Priority.<br>Set priority level for IRQ bit 24<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 15:14       | R/W | 0x0 | IRQ23_PRIO.<br>IRQ 23 Priority.<br>Set priority level for IRQ bit 23<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

| Offset:0x84 |     |     | Register Name: INTC_SRC_PRIO_REG1                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:12       | R/W | 0x0 | IRQ22_PRIO.<br>IRQ 22 Priority.<br>Set priority level for IRQ bit 22<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 11:10       | R/W | 0x0 | IRQ21_PRIO.<br>IRQ 21 Priority.<br>Set priority level for IRQ bit 21<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 9:8         | R/W | 0x0 | IRQ20_PRIO.<br>IRQ 20 Priority.<br>Set priority level for IRQ bit 20<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 7:6         | R/W | 0x0 | IRQ19_PRIO.<br>IRQ 19 Priority.<br>Set priority level for IRQ bit 19<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 5:4         | R/W | 0x0 | IRQ18_PRIO.<br>IRQ 18 Priority.<br>Set priority level for IRQ bit 18<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 3:2         | R/W | 0x0 | IRQ17_PRIO.<br>IRQ 17 Priority.<br>Set priority level for IRQ bit 17<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

| Offset:0x84 |                |                 | Register Name: INTC_SRC_PRIO_REG1                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 1:0         | R/W            | 0x0             | IRQ16_PRIO.<br>IRQ 16 Priority.<br>Set priority level for IRQ bit 16<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

#### 13.4.28. Interrupt Source Priority 2 Register (Default: 0x00000000)

| Offset:0x88 |                |                 | Register Name: INTC_SRC_PRIO_REG2                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 31:30       | R/W            | 0x0             | IRQ47_PRIO.<br>IRQ 47 Priority.<br>Set priority level for IRQ bit 47<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 29:28       | R/W            | 0x0             | IRQ46_PRIO.<br>IRQ 46 Priority.<br>Set priority level for IRQ bit 46<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 27:26       | R/W            | 0x0             | IRQ45_PRIO.<br>IRQ 45 Priority.<br>Set priority level for IRQ bit 45<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 25:24       | R/W            | 0x0             | IRQ44_PRIO.<br>IRQ 44 Priority.<br>Set priority level for IRQ bit 44<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 23:22       | R/W            | 0x0             | IRQ43_PRIO.<br>IRQ 43 Priority.                                                                                                                                                                         |

| Offset:0x88 |     |     | Register Name: INTC_SRC_PRIO_REG2                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | Set priority level for IRQ bit 43<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                                    |
| 21:20       | R/W | 0x0 | IRQ42_PRIO.<br>IRQ 42 Priority.<br>Set priority level for IRQ bit 42<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 19:18       | R/W | 0x0 | IRQ41_PRIO.<br>IRQ 41 Priority.<br>Set priority level for IRQ bit 41<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 17:16       | R/W | 0x0 | IRQ40_PRIO.<br>IRQ 40 Priority.<br>Set priority level for IRQ bit 40<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 15:14       | R/W | 0x0 | IRQ39_PRIO.<br>IRQ 39 Priority.<br>Set priority level for IRQ bit 39<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 13:12       | R/W | 0x0 | IRQ38_PRIO.<br>IRQ 38 Priority.<br>Set priority level for IRQ bit 38<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 11:10       | R/W | 0x0 | IRQ37_PRIO.<br>IRQ 37 Priority.                                                                                                                                                                         |

| Offset:0x88 |     |     | Register Name: INTC_SRC_PRIO_REG2                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | Set priority level for IRQ bit 37<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                                    |
| 9:8         | R/W | 0x0 | IRQ36_PRIO.<br>IRQ 36 Priority.<br>Set priority level for IRQ bit 36<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 7:6         | R/W | 0x0 | IRQ35_PRIO.<br>IRQ 35 Priority.<br>Set priority level for IRQ bit 35<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 5:4         | R/W | 0x0 | IRQ34_PRIO.<br>IRQ 34 Priority.<br>Set priority level for IRQ bit 34<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 3:2         | R/W | 0x0 | IRQ33_PRIO.<br>IRQ 33 Priority.<br>Set priority level for IRQ bit 33<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 1:0         | R/W | 0x0 | IRQ32_PRIO.<br>IRQ 32 Priority.<br>Set priority level for IRQ bit 32<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

### 13.4.29. Interrupt Source Priority 3 Register (Default: 0x00000000)

| Offset:0x8C |                |                 | Register Name: INTC_SRC_PRIO_REG3                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 31:30       | R/W            | 0x0             | IRQ63_PRIO.<br>IRQ 63 Priority.<br>Set priority level for IRQ bit 63<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 29:28       | R/W            | 0x0             | IRQ62_PRIO.<br>IRQ 62 Priority.<br>Set priority level for IRQ bit 62<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 27:26       | R/W            | 0x0             | IRQ61_PRIO.<br>IRQ 61 Priority.<br>Set priority level for IRQ bit 61<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 25:24       | R/W            | 0x0             | IRQ60_PRIO.<br>IRQ 60 Priority.<br>Set priority level for IRQ bit 60<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 23:22       | R/W            | 0x0             | IRQ59_PRIO.<br>IRQ 59 Priority.<br>Set priority level for IRQ bit 59<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 21:20       | R/W            | 0x0             | IRQ58_PRIO.<br>IRQ 58 Priority.<br>Set priority level for IRQ bit 58<br>Level0 = 0x0 level 0, lowest priority                                                                                           |

| Offset:0x8C |     |     | Register Name: INTC_SRC_PRIO_REG3                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                                                                                                                  |
| 19:18       | R/W | 0x0 | IRQ57_PRIO.<br>IRQ 57 Priority.<br>Set priority level for IRQ bit 57<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 17:16       | R/W | 0x0 | IRQ56_PRIO.<br>IRQ 56 Priority.<br>Set priority level for IRQ bit 56<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 15:14       | R/W | 0x0 | IRQ55_PRIO.<br>IRQ 55 Priority.<br>Set priority level for IRQ bit 55<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 13:12       | R/W | 0x0 | IRQ54_PRIO.<br>IRQ 54 Priority.<br>Set priority level for IRQ bit 54<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 11:10       | R/W | 0x0 | IRQ53_PRIO.<br>IRQ 53 Priority.<br>Set priority level for IRQ bit 53<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 9:8         | R/W | 0x0 | IRQ52_PRIO.<br>IRQ 52 Priority.<br>Set priority level for IRQ bit 52<br>Level0 = 0x0 level 0, lowest priority                                                                                           |

| Offset:0x8C |     |     | Register Name: INTC_SRC_PRIO_REG3                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                                                                                                                  |
| 7:6         | R/W | 0x0 | IRQ51_PRIO.<br>IRQ 51 Priority.<br>Set priority level for IRQ bit 51<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 5:4         | R/W | 0x0 | IRQ50_PRIO.<br>IRQ 50 Priority.<br>Set priority level for IRQ bit 50<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 3:2         | R/W | 0x0 | IRQ49_PRIO.<br>IRQ 49 Priority.<br>Set priority level for IRQ bit 49<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 1:0         | R/W | 0x0 | IRQ48_PRIO.<br>IRQ 48 Priority.<br>Set priority level for IRQ bit 48<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

#### 13.4.30. Interrupt Source Priority 4 Register (Default: 0x00000000)

| Offset:0x90 |                |                 | Register Name: INTC_SRC_PRIO_REG4                                                                                                                             |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                   |
| 31:30       | R/W            | 0x0             | IRQ79_PRIO.<br>IRQ 79 Priority.<br>Set priority level for IRQ bit 79<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2 |

| Offset:0x90 |     |     | Register Name: INTC_SRC_PRIO_REG4                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | Level3 = 0x1 level 3, highest priority                                                                                                                                                                  |
| 29:28       | R/W | 0x0 | IRQ78_PRIO.<br>IRQ 78 Priority.<br>Set priority level for IRQ bit 78<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 27:26       | R/W | 0x0 | IRQ77_PRIO.<br>IRQ 77 Priority.<br>Set priority level for IRQ bit 77<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 25:24       | R/W | 0x0 | IRQ76_PRIO.<br>IRQ 76 Priority.<br>Set priority level for IRQ bit 76<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 23:22       | R/W | 0x0 | IRQ75_PRIO.<br>IRQ 75 Priority.<br>Set priority level for IRQ bit 75<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 21:20       | R/W | 0x0 | IRQ74_PRIO.<br>IRQ 74 Priority.<br>Set priority level for IRQ bit 74<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 19:18       | R/W | 0x0 | IRQ73_PRIO.<br>IRQ 73 Priority.<br>Set priority level for IRQ bit 73<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2                                           |

|             |     |     |                                                                                                                                                                                                         |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset:0x90 |     |     | Register Name: INTC_SRC_PRIO_REG4                                                                                                                                                                       |
|             |     |     | Level3 = 0x1 level 3, highest priority                                                                                                                                                                  |
| 17:16       | R/W | 0x0 | IRQ72_PRIO.<br>IRQ 72 Priority.<br>Set priority level for IRQ bit 72<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 15:14       | R/W | 0x0 | IRQ71_PRIO.<br>IRQ 71 Priority.<br>Set priority level for IRQ bit 71<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 13:12       | R/W | 0x0 | IRQ70_PRIO.<br>IRQ 70 Priority.<br>Set priority level for IRQ bit 70<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 11:10       | R/W | 0x0 | IRQ69_PRIO.<br>IRQ 69 Priority.<br>Set priority level for IRQ bit 69<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 9:8         | R/W | 0x0 | IRQ68_PRIO.<br>IRQ 68 Priority.<br>Set priority level for IRQ bit 68<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 7:6         | R/W | 0x0 | IRQ67_PRIO.<br>IRQ 67 Priority.<br>Set priority level for IRQ bit 67<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2                                           |

|             |     |     |                                                                                                                                                                                                         |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset:0x90 |     |     | Register Name: INTC_SRC_PRIO_REG4                                                                                                                                                                       |
|             |     |     | Level3 = 0x1 level 3, highest priority                                                                                                                                                                  |
| 5:4         | R/W | 0x0 | IRQ66_PRIO.<br>IRQ 66 Priority.<br>Set priority level for IRQ bit 66<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 3:2         | R/W | 0x0 | IRQ65_PRIO.<br>IRQ 65 Priority.<br>Set priority level for IRQ bit 65<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 1:0         | R/W | 0x0 | IRQ64_PRIO.<br>IRQ 64 Priority.<br>Set priority level for IRQ bit 64<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |

#### 13.4.31. Interrupt Source Priority 5 Register (Default: 0x00000000)

| Offset:0x94 |                |                 | Register Name: INTC_SRC_PRIO_REG5                                                                                                                                                                       |
|-------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                             |
| 31:30       | R/W            | 0x0             | IRQ95_PRIO.<br>IRQ 95 Priority.<br>Set priority level for IRQ bit 95<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 29:28       | R/W            | 0x0             | IRQ94_PRIO.<br>IRQ 94 Priority.<br>Set priority level for IRQ bit 94<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 27:26       | R/W            | 0x0             | IRQ93_PRIO.                                                                                                                                                                                             |

| Offset:0x94 |     |     | Register Name: INTC_SRC_PRIO_REG5                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | IRQ 93 Priority.<br>Set priority level for IRQ bit 93<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                |
| 25:24       | R/W | 0x0 | IRQ92_PRIO.<br>IRQ 92 Priority.<br>Set priority level for IRQ bit 92<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 23:22       | R/W | 0x0 | IRQ91_PRIO.<br>IRQ 91 Priority.<br>Set priority level for IRQ bit 91<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 21:20       | R/W | 0x0 | IRQ90_PRIO.<br>IRQ 90 Priority.<br>Set priority level for IRQ bit 90<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 19:18       | R/W | 0x0 | IRQ89_PRIO.<br>IRQ 89 Priority.<br>Set priority level for IRQ bit 89<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 17:16       | R/W | 0x0 | IRQ88_PRIO.<br>IRQ 88 Priority.<br>Set priority level for IRQ bit 88<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 15:14       | R/W | 0x0 | IRQ87_RPIO.                                                                                                                                                                                             |

| Offset:0x94 |     |     | Register Name: INTC_SRC_PRIO_REG5                                                                                                                                                                       |
|-------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | IRQ 87 Priority.<br>Set priority level for IRQ bit 87<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority                |
| 13:12       | R/W | 0x0 | IRQ86_RPIO.<br>IRQ 86 Priority.<br>Set priority level for IRQ bit 86<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 11:10       | R/W | 0x0 | IRQ85_PRIO.<br>IRQ 85 Priority.<br>Set priority level for IRQ bit 85<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 9:8         | R/W | 0x0 | IRQ84_PRIO.<br>IRQ 84 Priority.<br>Set priority level for IRQ bit 84<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 7:6         | R/W | 0x0 | IRQ83_PRIO.<br>IRQ 83 Priority.<br>Set priority level for IRQ bit 83<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 5:4         | R/W | 0x0 | IRQ82_PRIO.<br>IRQ 82 Priority.<br>Set priority level for IRQ bit 82<br>Level0 = 0x0 level 0, lowest priority<br>Level1 = 0x1 level 1<br>Level2 = 0x1 level 2<br>Level3 = 0x1 level 3, highest priority |
| 3:2         | R/W | 0x0 | IRQ81_PRIO.                                                                                                                                                                                             |

| Offset:0x94 |     |     | Register Name: INTC_SRC_PRIO_REG5                                                                                                                                                                                          |
|-------------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |     |     | <p>IRQ 81 Priority.<br/> Set priority level for IRQ bit 81<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x1 level 2<br/> Level3 = 0x1 level 3, highest priority</p>                  |
| 1:0         | R/W | 0x0 | <p>IRQ80_PRIO.<br/> IRQ 80 Priority.<br/> Set priority level for IRQ bit 80<br/> Level0 = 0x0 level 0, lowest priority<br/> Level1 = 0x1 level 1<br/> Level2 = 0x1 level 2<br/> Level3 = 0x1 level 3, highest priority</p> |

## 14. DMA Controller

### 14.1. Overview

There are two kinds of DMA in the chip: 8-channel Normal DMA and 8-channel Dedicated DMA. For normal DMA, only one channel can be active and the sequence is in accordance with priority level while for the dedicated DMA, at most 8-channel can be active at the same time if their source or destination does not conflict.

### 14.2. DMA Description

DMA can support 8-bit/16-bit/32-bit data width. The data width of Source and Destination can be different, but the address should be aligned.

### 14.3. DMA Register List

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

| Register Name         | Offset            | Description                                        |
|-----------------------|-------------------|----------------------------------------------------|
| DMA_IRQ_EN_REG        | 0x0000            | DMA IRQ Enable                                     |
| DMA_IRQ_PEND_STAS_REG | 0x0004            | DMA IRQ Pending Status                             |
| NDMA_CTRL_REG         | 0x100+N*0x20      | Normal DMA Configuration<br>(N=0,1,2,3,4,5,6,7)    |
| NDMA_SRC_ADDR_REG     | 0x100+N*0x20+4    | Normal DMA Source Address                          |
| NDMA_DEST_ADDR_REG    | 0x100+N*0x20+8    | Normal DMA Destination Address                     |
| NDMA_BC_REG           | 0x100+N*0x20+C    | Normal DMA Byte Counter                            |
| DDMA_CFG_REG          | 0x300+N*0x20      | Dedicated DMA Configuration<br>(N=0,1,2,3,4,5,6,7) |
| DDMA_SRC_ADDR_REG     | 0x300+N*0x20+4    | Dedicated DMA Source Start Address                 |
| DDMA_DEST_ADDR_REG    | 0x300+N*0x20+8    | Dedicated DMA Destination Start Address            |
| DDMA_BC_REG           | 0x300+N*0x20+C    | Dedicated DMA Byte Counter                         |
| DDMA_PARA_REG         | 0x300+N*0x20+0x18 | Dedicated DMA Parameter                            |

### 14.4. DMA Register Description

#### 14.4.1. DMA IRQ Enable Register (Default: 0x00000000)

| Offset: 0x00 |                | Register Name: DMA_IRQ_EN_REG |                   |
|--------------|----------------|-------------------------------|-------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex               | Description       |
| 31           | R/W            | 0x0                           | DDMA7_END_IRQ_EN. |

|    |     |     |                                                                                               |
|----|-----|-----|-----------------------------------------------------------------------------------------------|
|    |     |     | Dedicated DMA 7 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.                      |
| 30 | R/W | 0x0 | DDMA7_HF_IRQ_EN.<br>Dedicated DMA 7 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 29 | R/W | 0x0 | DDMA6_END_IRQ_EN.<br>Dedicated DMA 6 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 28 | R/W | 0x0 | DDMA6_HF_IRQ_EN.<br>Dedicated DMA 6 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 27 | R/W | 0x0 | DDMA5_END_IRQ_EN.<br>Dedicated DMA 5 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 26 | R/W | 0x0 | DDMA5_HF_IRQ_EN.<br>Dedicated DMA 5 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 25 | R/W | 0x0 | DDMA4_END_IRQ_EN.<br>Dedicated DMA 4 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 24 | R/W | 0x0 | DDMA4_HF_IRQ_EN.<br>Dedicated DMA 4 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 23 | R/W | 0x0 | DDMA3_END_IRQ_EN.<br>Dedicated DMA 3 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 22 | R/W | 0x0 | DDMA3_HF_IRQ_EN.<br>Dedicated DMA 3 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 21 | R/W | 0x0 | DDMA2_END_IRQ_EN.<br>Dedicated DMA 2 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 20 | R/W | 0x0 | DDMA2_HF_IRQ_EN.<br>Dedicated DMA 2 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 19 | R/W | 0x0 | DDMA1_END_IRQ_EN.<br>Dedicated DMA 1 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 18 | R/W | 0x0 | DDMA1_HF_IRQ_EN.<br>Dedicated DMA 1 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 17 | R/W | 0x0 | DDMA0_END_IRQ_EN.<br>Dedicated DMA 0 End Transfer Interrupt Enable.                           |

|    |     |     |                                                                                               |
|----|-----|-----|-----------------------------------------------------------------------------------------------|
|    |     |     | 0: Disable, 1: Enable.                                                                        |
| 16 | R/W | 0x0 | DDMA0_HF_IRQ_EN.<br>Dedicated DMA 0 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 15 | R/W | 0x0 | NDMA7_END_IRQ_EN.<br>Normal DMA 7 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 14 | R/W | 0x0 | NDMA7_HF_IRQ_EN.<br>Normal DMA 7 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 13 | R/W | 0x0 | NDMA6_END_IRQ_EN.<br>Normal DMA 6 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 12 | R/W | 0x0 | NDMA6_HF_IRQ_EN.<br>Normal DMA 6 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 11 | R/W | 0x0 | NDMA5_END_IRQ_EN.<br>Normal DMA 5 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 10 | R/W | 0x0 | NDMA5_HF_IRQ_EN.<br>Normal DMA 5 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 9  | R/W | 0x0 | NDMA4_END_IRQ_EN.<br>Normal DMA 4 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 8  | R/W | 0x0 | NDMA4_HF_IRQ_EN.<br>Normal DMA 4 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 7  | R/W | 0x0 | NDMA3_END_IRQ_EN.<br>Normal DMA 3 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 6  | R/W | 0x0 | NDMA3_HF_IRQ_EN.<br>Normal DMA 3 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 5  | R/W | 0x0 | NDMA2_END_IRQ_EN.<br>Normal DMA 2 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 4  | R/W | 0x0 | NDMA2_HF_IRQ_EN.<br>Normal DMA 2 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |
| 3  | R/W | 0x0 | NDMA1_END_IRQ_EN.<br>Normal DMA 1 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable.    |

|   |     |     |                                                                                            |
|---|-----|-----|--------------------------------------------------------------------------------------------|
| 2 | R/W | 0x0 | NDMA1_HF_IRQ_EN.<br>Normal DMA 1 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 1 | R/W | 0x0 | NDMA0_END_IRQ_EN.<br>Normal DMA 0 End Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |
| 0 | R/W | 0x0 | NDMA0_HF_IRQ_EN.<br>Normal DMA 0 Half Transfer Interrupt Enable.<br>0: Disable, 1: Enable. |

#### 14.4.2. DMA IRQ Pending Status Register (Default: 0x00000000)

| Offset: 0x04 |                 |                 | Register Name: DMA_IRQ_PEND_STAS_REG                                                                                                |
|--------------|-----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W/<br>rite | Default/<br>Hex | Description                                                                                                                         |
| 31           | R/W             | 0x0             | DDMA7_END_IRQ_PEND.<br>Dedicated DMA 7 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 30           | R/W             | 0x0             | DDMA7_HF_IRQ_PEND.<br>Dedicated DMA 7 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 29           | R/W             | 0x0             | DDMA6_END_IRQ_PEND.<br>Dedicated DMA 6 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 28           | R/W             | 0x0             | DDMA6_HF_IRQ_PEND.<br>Dedicated DMA 6 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 27           | R/W             | 0x0             | DDMA5_END_IRQ_PEND.<br>Dedicated DMA 5 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 26           | R/W             | 0x0             | DDMA5_HF_IRQ_PEND.<br>Dedicated DMA 5 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 25           | R/W             | 0x0             | DDMA4_END_IRQ_PEND.<br>Dedicated DMA 4 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 24           | R/W             | 0x0             | DDMA4_HF_IRQ_PEND.                                                                                                                  |

|    |     |     |                                                                                                                                     |
|----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | Dedicated DMA 4 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending.                       |
| 23 | R/W | 0x0 | DDMA3_END_IRQ_PEND.<br>Dedicated DMA 3 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 22 | R/W | 0x0 | DDMA3_HF_IRQ_PEND.<br>Dedicated DMA 3 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 21 | R/W | 0x0 | DDMA2_END_IRQ_PEND.<br>Dedicated DMA 2 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 20 | R/W | 0x0 | DDMA2_HF_IRQ_PEND.<br>Dedicated DMA 2 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 19 | R/W | 0x0 | DDMA1_END_IRQ_PEND.<br>Dedicated DMA 1 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 18 | R/W | 0x0 | DDMA1_HF_IRQ_PEND.<br>Dedicated DMA 1 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 17 | R/W | 0x0 | DDMA0_END_IRQ_PEND.<br>Dedicated DMA 0 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 16 | R/W | 0x0 | DDMA0_HF_IRQ_PEND.<br>Dedicated DMA 0 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 15 | R/W | 0x0 | NDMA7_END_IRQ_PEND.<br>Normal DMA 7 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending.    |
| 14 | R/W | 0x0 | NDMA7_HF_IRQ_PEND.<br>Normal DMA 7 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending.    |

|    |     |     |                                                                                                                                  |
|----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------|
| 13 | R/W | 0x0 | NDMA6_END_IRQ_PEND.<br>Normal DMA 6 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 12 | R/W | 0x0 | NDMA6_HF_IRQ_PEND.<br>Normal DMA 6 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 11 | R/W | 0x0 | NDMA5_END_IRQ_PEND.<br>Normal DMA 5 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 10 | R/W | 0x0 | NDMA5_HF_IRQ_PEND.<br>Normal DMA 5 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 9  | R/W | 0x0 | NDMA4_END_IRQ_PEND.<br>Normal DMA 4 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 8  | R/W | 0x0 | NDMA4_HF_IRQ_PEND.<br>Normal DMA 4 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 7  | R/W | 0x0 | NDMA3_END_IRQ_PEND.<br>Normal DMA 3 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 6  | R/W | 0x0 | NDMA3_HF_IRQ_PEND.<br>Normal DMA 3 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 5  | R/W | 0x0 | NDMA2_END_IRQ_PEND.<br>Normal DMA 2 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 4  | R/W | 0x0 | NDMA2_HF_IRQ_PEND.<br>Normal DMA 2 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 3  | R/W | 0x0 | NDMA1_END_IRQ_PEND.<br>Normal DMA 1 End Transfer Interrupt Pending. Set 1 to the bit will clear it.                              |

|   |     |     |                                                                                                                                  |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: No effect, 1: Pending.                                                                                                        |
| 2 | R/W | 0x0 | NDMA1_HF_IRQ_PEND.<br>Normal DMA 1 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 1 | R/W | 0x0 | NDMA0_END_IRQ_PEND.<br>Normal DMA 0 End Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |
| 0 | R/W | 0x0 | NDMA0_HF_IRQ_PEND.<br>Normal DMA 0 Half Transfer Interrupt Pending. Set 1 to the bit will clear it.<br>0: No effect, 1: Pending. |

#### 14.4.3. Normal DMA Configuration Register (Default: 0x00000000) (N=0:7)

| Offset: 0x100+N*0x20<br>(N=0,1,2,3,4,5,6,7) |             |              | Register Name: NDMA_CTRL_REG                                                                                                                                                                                                                               |
|---------------------------------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                         | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                                                |
| 31                                          | R/W         | 0x0          | NDMA_LOAD.<br>DMA Loading.<br>If set to 1, DMA will start and load the DMA registers to the shadow registers. The bit will hold on until the DMA finishes. It will be cleared automatically.<br>Set 0 to the bit will reset the corresponding DMA channel. |
| 30                                          | R/W         | 0x0          | NDMA_CONTI_EN.<br>DMA Continuous Mode Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                    |
| 29:27                                       | R/W         | 0x0          | NDMA_WAIT_STATE.<br>DMA Wait State.<br>0: wait for 0 DMA clock to request,<br>...<br>7: wait for 2(n+1) DMA clock to request.                                                                                                                              |
| 26:25                                       | R/W         | 0x0          | NDMA_DST_DATA_WIDTH.<br>Normal DMA Destination Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: /                                                                                                                                               |
| 24:23                                       | R/W         | 0x0          | NDMA_DST_BST_LEN.<br>DMA Destination Burst Length.<br>00: 1,<br>01: 4                                                                                                                                                                                      |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 10: 8<br>11: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 22    | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 21    | R/W | 0x0 | NDMA_DST_ADDR_TYPE.<br>Normal DMA Destination Address Type.<br>0: Increment<br>1: No Change.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 20:16 | R/W | 0x0 | NDMA_DST_DRQ_TYPE.<br>Normal DMA Destination DRQ Type.<br>00000 : IR-TX<br>00001 : /<br>00010 : /<br>00011 : IIS-TX<br>00100 : /<br>00101 : /<br>00110 : /<br>00111 : /<br>01000 : UART0 TX<br>01001 : UART1 TX<br>01010 : UART2 TX<br>01011 : UART3 TX<br>01100 : /<br>01101 : /<br>01110 : /<br>01111 : /<br>10000 : HDMI DDC TX<br>10001 : /<br>10010 : /<br>10011 : Audio Codec D/A<br>10100 : /<br>10101 : SRAM(range : )<br>10110 : SDRAM<br>10111 : /<br>11000 : SPI0 TX<br>11001 : SPI1 TX<br>11010 : SPI2 TX<br>11011 : USB EP1<br>11100 :USB EP2<br>11101 :USB EP3<br>11110 :USB EP4<br>11111 :USB EP5 |
| 15    | R/W | 0x0 | BC_MODE_SEL.<br>BC mode select.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                       |
|-------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0 : normal mode(the value read back equals to the value that is written)<br>1: remain mode (the value read back equals to the remain counter to be transferred).                                                                                                                                                                                      |
| 14:10 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                     |
| 10:9  | R/W | 0x0 | NDMA_SRC_DATA_WIDTH.<br>Normal DMA Source Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: /                                                                                                                                                                                                                                               |
| 8:7   | R/W | 0x0 | NDMA_SRC_BST_LEN.<br>DMA Source Burst Length.<br>00: 1<br>01: 4<br>10: 8<br>11: /.                                                                                                                                                                                                                                                                    |
| 6     | /   | /   | /                                                                                                                                                                                                                                                                                                                                                     |
| 5     | R/W | 0x0 | NDMA_SRC_ADDR_TYPE.<br>Normal DMA Source Address Type.<br>0: Increment<br>1: No Change                                                                                                                                                                                                                                                                |
| 4:0   | R/W | 0x0 | NDMA_SRC_DRQ_TYPE.<br>Normal DMA Source DRQ Type.<br>00000 : IR-RX<br>00001 : /<br>00010 : /<br>00011 : IIS-RX<br>00100 : /<br>00101 : /<br>00110 :<br>00111 : /<br>01000 : UART0 RX<br>01001 : UART1 RX<br>01010 : UART2 RX<br>01011 : UART3 RX<br>01100 : /<br>01101 : /<br>01110 : /<br>01111 : /<br>10000 : HDMI DDC RX<br>10001 : /<br>10010 : / |

|  |  |  |                                                                                                                                                                                                                                                       |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 10011 : Audio Codec A/D<br>10100 : /<br>10101 : SRAM(range : )<br>10110 : SDRAM<br>10111 : TP A/D<br>11000 : SPI0 RX<br>11001 : SPI1 RX<br>11010 : SPI2 RX<br>11011 : USB EP1<br>11100 :USB EP2<br>11101 :USB EP3<br>11110 :USB EP4<br>11111 :USB EP5 |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 14.4.4. Normal DMA Source Address Register (Default: 0x00000000)

| Offset: 0x100+N*0x20+0x4<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: NDMA_SRC_ADDR_REG             |
|-------------------------------------------------|----------------|-----------------|----------------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                                  |
| 31:0                                            | R/W            | x               | NDMA_SRC_ADDR.<br>Normal DMA Source Address. |

#### 14.4.5. Normal DMA Destination Address Register (Default: 0x00000000)

| Offset: 0x100+N*0x20+0x8<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: NDMA_DEST_ADDR_REG                 |
|-------------------------------------------------|----------------|-----------------|---------------------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                                       |
| 31:0                                            | R/W            | x               | NDMA_DST_ADDR.<br>Normal DMA Destination Address. |

#### 14.4.6. Normal DMA Byte Counter Register (Default: 0x00000000)

| Offset: 0x100+N*0x20+0xC<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: NDMA_BC_REG           |
|-------------------------------------------------|----------------|-----------------|--------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                          |
| 31:24                                           | /              | /               | /                                    |
| 23:0                                            | R/W            | x               | NDMA_BC.<br>Normal DMA Byte Counter. |

Note: If ByteCounter=0, DMA will transfer no byte. The maximum value is 128k.

#### 14.4.7. Dedicated DMA Configuration Register (Default: 0x00000000)

|                                             |                             |
|---------------------------------------------|-----------------------------|
| Offset: 0x300+N*0x20<br>(N=0,1,2,3,4,5,6,7) | Register Name: DDMA_CFG_REG |
|---------------------------------------------|-----------------------------|

| Bit   | Read /Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
|-------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W         | 0x0         | DDMA_LOAD.<br>DMA Loading.<br>If set to 1, DMA will start and load the DMA registers to the shadow registers. The bit will hold on until the DMA finishes. It will be cleared automatically.<br>Set 0 to the bit will stop the corresponding DMA channel and reset its state machine. |
| 30    | R           | 0x0         | DDMA_BSY_STA.<br>DMA Busy Status.<br>0: DMA idle<br>1: DMA busy.                                                                                                                                                                                                                      |
| 29    | R/W         | 0x0         | DDMA_CONTI_MODE_EN.<br>DMA Continuous Mode Enable.<br>0: Disable, 1: Enable.                                                                                                                                                                                                          |
| 28    | /           | /           | /                                                                                                                                                                                                                                                                                     |
| 27    | /           | /           | /                                                                                                                                                                                                                                                                                     |
| 26:25 | R/W         | 0x0         | DDMA_DST_DATA_WIDTH.<br>DMA Destination Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: /                                                                                                                                                                                 |
| 24:23 | R/W         | 0x0         | DDMA_DST_BST_LEN.<br>DMA Destination Burst Length.<br>00: 1,<br>01: 4.<br>10: 8<br>11: /.                                                                                                                                                                                             |
| 22:21 | R/W         | 0x0         | DDMA_ADDR_MODE.<br>DMA Destination Address Mode<br>DMA Source Address Mode<br>0x0: Linear Mode<br>0x1: IO Mode<br>0x2: Horizontal Page Mode<br>0x3: Vertical Page Mode                                                                                                                |
| 20:16 | R/W         | 0x0         | DDMA_DST_DRQ_SEL.<br>Dedicated DMA Destination DRQ Type<br>0x0: SRAM memory<br>0x1: SDRAM memory<br>0x2: /<br>0x3: NAND Flash Controller (NFC)                                                                                                                                        |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 0x4: USB0<br>0x5: /<br>0x6: Ethernet MAC Tx<br>0x7: /<br>0x8: SPI1 TX<br>0x9: /<br>0xA: Security System Tx<br>0xB: /<br>0xC: /<br>0xD: /<br>0xE: TCON0<br>0xF: /<br>0x10: /<br>0x11: /<br>0x12: /<br>0x13: /<br>0x14: /<br>0x15: /<br>0x16: /<br>0x17: /<br>0x18: HDMI Audio<br>0x19: /<br>0x1A: SPI0 TX<br>0x1B: /.<br>0x1C: SPI2 TX<br>0x1D: /<br>0x1E: /<br>0x1F: / |
| 15    | R/W | 0x0 | BC_MODE_SEL.<br>BC mode select.<br>0 : normal mode(the value read back equals to the value that is written)<br>1: remain mode (the value read back equals to the remain counter to be transferred).                                                                                                                                                                    |
| 14:11 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                      |
| 10:9  | R/W | 0x0 | DDMA_SRC_DATA_WIDTH.<br>DMA Source Data Width.<br>00: 8-bit<br>01: 16-bit<br>10: 32-bit<br>11: /                                                                                                                                                                                                                                                                       |
| 8:7   | R/W | 0x0 | DDMA_SRC_BST_LEN.<br>DMA Source Burst Length.<br>00: 1                                                                                                                                                                                                                                                                                                                 |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 01: 4<br>10: 8<br>11: /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:5 | R/W | 0x0 | DDMA_SRC_ADDR_MODE.<br>DMA Source Address Mode<br>0x0: Linear Mode<br>0x1: IO Mode<br>0x2: Horizontal Page Mode<br>0x3: Vertical Page Mode                                                                                                                                                                                                                                                                                                                                                              |
| 4:0 | R/W | 0x0 | DDMA_SRC_DRQ_TYPE.<br>Dedicated DMA Source DRQ Type<br>0x0: SRAM memory<br>0x1: SDRAM memory<br>0x2: /<br>0x3: NAND Flash Controller (NFC)<br>0x4: USB0<br>0x5: /<br>0x6: /<br>0x7: Ethernet MAC Rx<br>0x8: /<br>0x9: SPI1 RX<br>0xA: /<br>0xB: Security System Rx<br>0xC: /<br>0xD: /<br>0xE: /<br>0xF: /<br>0x10: /<br>0x11: /<br>0x12: /<br>0x13: /<br>0x14: /<br>0x15: /<br>0x16: /<br>0x17: /<br>0x18: /<br>0x19: /<br>0x1A: /<br>0x1B: SPI0 RX.<br>0x1C: /<br>0x1D: SPI2 RX<br>0x1E: /<br>0x1F: / |

#### 14.4.8. Dedicated DMA Source Start Address Register (N=0:7)

| Offset: 0x300+N*0x20+0x4<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: DDMA_SRC_ADDR_REG                            |
|-------------------------------------------------|----------------|-----------------|-------------------------------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                                                 |
| 31:0                                            | R/W            | x               | DDMA_SRC_START_ADDR.<br>Dedicated DMA Source Start Address. |

#### 14.4.9. Dedicated DMA Destination Start Address Register (N=0:7)

| Offset: 0x300+N*0x20+0x8<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: DDMA_DEST_ADDR_REG                                |
|-------------------------------------------------|----------------|-----------------|------------------------------------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                                                      |
| 31:0                                            | R/W            | x               | DDMA_DST_START_ADDR.<br>Dedicated DMA Destination Start Address. |

#### 14.4.10. Dedicated DMA Byte Counter Register (N=0:7)

| Offset: 0x300+N*0x20+0xc<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: DDMA_BC_REG              |
|-------------------------------------------------|----------------|-----------------|-----------------------------------------|
| Bit                                             | Read/W<br>rite | Default/<br>Hex | Description                             |
| 31:25                                           | /              | /               | /                                       |
| 24:0                                            | R/W            | x               | DDMA_BC.<br>Dedicated DMA Byte Counter. |

Note: If ByteCounter=0, DMA will transfer no byte. The maximum value is 0x1000000.

#### 14.4.11. Dedicated DMA Parameter Register

| Offset: 0x300+N*0x20+0x18<br>(N=0,1,2,3,4,5,6,7) |                |                 | Register Name: DDMA PARA_REG                          |
|--------------------------------------------------|----------------|-----------------|-------------------------------------------------------|
| Bit                                              | Read/W<br>rite | Default/<br>Hex | Description                                           |
| 31:24                                            | R/W            | 0x0             | DEST_DATA_BLK_SIZE.<br>Destination Data Block Size n. |
| 23:16                                            | R/W            | 0x0             | DEST_WAIT_CLK_CYC.<br>Destination Wait Clock Cycles n |
| 15:8                                             | R/W            | 0x0             | SRC_DATA_BLK_SIZE.<br>Source Data Block Size n.       |
| 7:0                                              | R/W            | x               | SRC_WAIT_CLK_CYC.<br>Source Wait Clock Cycles n.      |

Note: If the counter is N, the value is N+1.

## 15. NAND Flash Controller

### 15.1. Overview

The NAND Flash Controller (NFC) supports all NAND/MLC flash memory available in the market and new types can be supported by software re-configuration as well. There are 4 separate chip select lines (CE#) to connect up to 4 flash chips with 2 R/B signals.

The On-the-fly error correction code (ECC) is built in NFC to enhance reliability. BCH is implemented to detect and correct up to 64 bits error per 512 or 1024 bytes data. The on chip ECC and parity checking circuitry of NFC frees CPU for other tasks. The ECC function can be disabled by software.

The data can be transferred by DMA or by CPU memory-mapped IO method. The NFC provides automatic timing control to read or write external Flash. The NFC maintains the proper relativity for CLE, CE# and ALE control signal lines. Three kinds of modes are supported for serial read access: Mode 0 is the conventional serial access, Mode 1 for EDO type, and Mode 2 is for extension EDO type. In addition, NFC can monitor the status of R/B# signal line.

Block management and wear leveling management are implemented in software.

The NFC features:

- Support SLC/MLC/TLC flash and EF-NAND memory
- Software configure seed to randomize engine
- Software configure method for adaptability to a variety of system and memory types
- Support 8-bit Data Bus Width
- Support 1024, 2048, 4096, 8192, 16384 bytes size per page
- Up to 4 flash chips which are controlled by NFC\_CEx#
- Support Conventional and EDO serial access method for serial reading Flash
- On-the-fly BCH error correction code which correcting up to 64 bits per 512 or 1024 bytes
- Corrected Error bits number information report
- NFC status information is reported by its registers and support interrupt
- One Command FIFO
- Support external DMA for data transfer
- Two 256x32-bit RAM for Pipeline Procession
- Support SDR, DDR and Toggle NAND

## 15.2. NFC Block Diagram



Figure 15-1 NFC Block Diagram

## 15.3. NFC Timing Diagram

Typically, there are two kinds of serial access method. One is the conventional method that fetches data at the rise edge of NFC<sub>\_</sub>RE# signal line, and the other is EDO type that fetches data at the next fall edge of NFC<sub>\_</sub>RE# signal line.



Figure 15-2 Conventional Serial Access Cycle Diagram (SAM0)



Figure 15-3 EDO Type Serial Access after Read Cycle (SAM1)



Figure 15-4 Extending EDO Type Serial Access Mode (SAM2)



Figure 15-5 Command Latch Cycle



Figure 15-6 Address Latch Cycle



Figure 15-7 Write Data to Flash Cycle



Figure15-8 Waiting R/B# Ready Diagram



Figure15-9 WE # High to RE# Low Timing Diagram



Figure15-10 RE # High to WE# Low Timing Diagram



Figure15-11 Address to Data Loading Timing Diagram

#### Timing Cycle List:

| ID  | Parameter                    | Timing | Notes                                                  |
|-----|------------------------------|--------|--------------------------------------------------------|
| T1  | NFC_CLE setup time           | T      |                                                        |
| T2  | NFC_CLE hold time            | T      |                                                        |
| T3  | NFC_CE setup time            | T      |                                                        |
| T4  | NFC_CE hold time             | T      |                                                        |
| T5  | NFC_WE# pulse width          | T      |                                                        |
| T6  | NFC_WE# hold time            | T      |                                                        |
| T7  | NFC_ALE setup time           | T      |                                                        |
| T8  | Data setup time              | T      |                                                        |
| T9  | Data hold time               | T      |                                                        |
| T10 | Ready to NFC_RE# low         | 3T     |                                                        |
| T11 | NFC_ALE hold time            | T      |                                                        |
| T12 | NFC_RE# pulse width          | T      |                                                        |
| T13 | NFC_RE# hold time            | T      |                                                        |
| T14 | Read cycle time              | 2T     |                                                        |
| T15 | Write cycle time             | 2T     |                                                        |
| T16 | NFC_WE# high to R/B# busy    | tWB    | Specified by timing configure register(NFC_TIMING_CFG) |
| T17 | NFC_WE# high to NFC_RE# low  | tWHR   | Specified by timing configure register(NFC_TIMING_CFG) |
| T18 | NFC_RE# high to NFC_WE# low  | tRHW   | Specified by timing configure register(NFC_TIMING_CFG) |
| T19 | Address to Data Loading time | tADL   | Specified by timing configure register(NFC_TIMING_CFG) |

Notes: T is the clock period duration of NFC\_CLK (x2).

## 15.4. NFC Operation Guide



Figure15-12 Page Read Command Diagram



Figure15-13 Page Program Diagram



Figure15-14 EF-NAND Page Read Diagram



Figure15-15 Interleave Page Read Diagram

## 16. SD/MMC Controller

### 16.1. Overview

The SD/MMC controller can be configured as a Secure Digital Multimedia Card controller, which simultaneously supports Secure Digital Memory (SD Memo), Secure Digital I/O (SDIO), Multimedia Card (MMC) and eMMC Card.

The SD/MMC controller features:

- Support Secure Digital memory protocol commands (up to SD2.0)
- Support Secure Digital I/O protocol commands
- Support Multimedia Card protocol commands (up to MMC4.3)
- Support eMMC boot operation
- Support one SD (Version1.0 to 2.0) or MMC (Version3.3 to 4.3)
- Support hardware CRC generation and error detection
- Support host pull-up control
- Support SDIO interrupts in 1-bit and 4-bit modes
- Support SDIO suspend and resume operation
- Support SDIO read wait
- Support block size of 1 to 65535 bytes
- Support descriptor-based internal DMA controller
- Internal 16x32-bit (64 bytes total) FIFO for data transfer

### 16.2. SD/MMC Timing Diagram

Please refer to relative Specifications listed below:

- Physical Layer Specification Ver2.00 Final
- SDIO Specification Ver2.00
- Multimedia Cards (MMC – version 4.2)
- JEDEC Standard – JESD84-44, Embedded Multimedia Card (eMMC) Card Product Standard

## 17. Two Wire Interface

### 17.1. Overview

This Two Wire Interface(TWI) Controller is designed to be an interface between CPU host and the serial two-wire bus, which supports all standard 2-Wire transfer, including Slave and Master. The communication to the two-wire bus is carried out on a byte-wise basis using interrupt or polled handshaking. This 2-Wire Controller can be operated in standard mode (100K bps) or fast-mode (up to 400K bps). Multiple Masters and 10-bit addressing Mode are supported for this specified application. General Call Addressing is supported in Slave mode.

The TWI controller features:

- Software-programmable for Slave or Master
- Support Repeated START signal
- Support Multi-master systems
- Support 10-bit addressing with two-wire bus
- Perform arbitration and clock synchronization
- Own address and General Call address detection
- Interrupt on address detection
- Support speed up to 400K bits/s ('fast mode')
- Support operation from a wide range of input clock frequencies

### 17.2. TWI Timing Diagram

Data are always transferred:

1. In unit of byte (8-bit);
2. Each byte followed by an acknowledge bit;
3. Unlimited number of byte in each data transfer;
4. Data are transferred in serial, with MSB first.
5. The receiver will hold SCL low to force the transmitter to enter a wait state while it is waiting for responses from the microprocessor after every byte transfer.

Acknowledge is indispensable in data transfer, and related acknowledge clock pulse is generated by the master. After sending a byte, the transmitter will release the SDA line, and one of the following two cases will occur:

- a. The SDA is pulled down by the receiver and an acknowledge signal is sent back;
- b. The SDA is left high, and a "not acknowledge" signal is sent back;

When the slave receiver doesn't acknowledge the slave address (because of resource deficiency), the SDA will be left high for master to generate a STOP condition to abort the transfer.

When the slave receiver acknowledges the slave address, but not ready to receive more during a data transfer, the SDA will be left high for the master to generate a STOP condition to abort the transfer.

The following diagram provides an illustration to the relation between SDA signal line and SCL signal line on the 2-Wire serial bus.



Figure 17-1 TWI Timing Diagram

### 17.3. TWI Controller Register List

| Module Name | Base Address |
|-------------|--------------|
| TWI0        | 0x01C2AC00   |
| TWI1        | 0x01C2B000   |
| TWI2        | 0x01C2B400   |

| Register Name | Offset | Description                  |
|---------------|--------|------------------------------|
| TWI_ADDR      | 0x0000 | TWI Slave address            |
| TWI_XADDR     | 0x0004 | TWI Extended slave address   |
| TWI_DATA      | 0x0008 | TWI Data byte                |
| TWI_CNTR      | 0x000C | TWI Control register         |
| TWI_STAT      | 0x0010 | TWI Status register          |
| TWI_CCR       | 0x0014 | TWI Clock control register   |
| TWI_SRST      | 0x0018 | TWI Software reset           |
| TWI_EFR       | 0x001C | TWI Enhance Feature register |
| TWI_LCR       | 0x0020 | TWI Line Control register    |

### 17.4. TWI Controller Register Description

#### 17.4.1. TWI Slave Address Register

|              |            |         |                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: TWI_ADDR<br>Default Value: 0x0000_0000                                |
| Bit          | Read/Write | Default | Description                                                                          |
| 31:8         | /          | /       | /                                                                                    |
|              |            |         | SLA<br>Slave address<br>7-bit addressing<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0 |
| 7:1          | R/W        | 0       | 10-bit addressing<br>1, 1, 1, 1, 0, SLAX[9:8]                                        |
| 0            | R/W        | 0       | GCE<br>General call address enable<br>0: Disable                                     |

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

Note:

For 7-bit addressing:

SLA6 – SLA0 is the 7-bit address of TWI in slave mode. When 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 two wire bus.) If GCE is set to ‘1’, the TWI will also recognize the general call address (00h).

For 10-bit addressing:

When the address received starts with 11110b, the TWI recognizes this as the first part of a 10-bit address and if the next two bits match ADDR[2:1] (i.e. SLAX9 and SLAX8 of the device’s extended address), it sends an ACK. (The device does not generate an interrupt at this point.) If the next byte of the address matches the XADDR register (SLAX7 – SLAX0), the TWI generates an interrupt and goes into slave mode.

#### 17.4.2. TWI Extend Address Register

| Offset: 0x04 |            |         | Register Name: TWI_XADDR<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|--------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                            |
| 31:8         | /          | /       | /                                                      |
|              |            |         | SLAX                                                   |
| 7:0          | R/W        | 0       | Extend Slave Address<br>SLAX[7:0]                      |

#### 17.4.3. TWI Data Register

| Offset: 0x08 |            |         | Register Name: 2WIRE_DATA<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|---------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                             |
| 31:8         | /          | /       | /                                                       |
| 7:0          | R/W        | 0       | Data byte for transmitting or receiving                 |

#### 17.4.4. TWI Control Register

| Offset: 0x0C |            |         | Register Name: TWI_CNTR<br>Default Value: 0x0000_0000                                                                                                     |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                               |
| 31:8         | /          | /       | /                                                                                                                                                         |
|              |            |         | INT_EN<br>Interrupt Enable<br>1'b0: The interrupt line always low<br>1'b1: The interrupt line will go high when INT_FLAG is set.                          |
| 7            | R/W        | 0       | BUS_EN<br>two-wire bus Enable<br>1'b0: The two-wire bus inputs ISDA/ISCL are ignored and the 2-Wire Controller will not respond to any address on the bus |
| 6            | R/W        | 0       |                                                                                                                                                           |

|   |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |   | 1'b1: The TWI will respond to calls to its slave address – and to the general call address if the GCE bit in the ADDR register is set.<br>Notes: In master operation mode, this bit should be set to '1'                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5 | R/W | 0 | <p><b>M_STA</b><br/> <b>Master Mode Start</b><br/> When M_STA is set to '1', TWI controller enters master mode and will transmit a START condition on the bus when the bus is free. If the M_STA bit is set to '1' when the 2-Wire Controller is already in master mode and one or more bytes have been transmitted, then a repeated START condition will be sent. If the M_STA bit is set to '1' when the TWI is being accessed in slave mode, the TWI will complete the data transfer in slave mode then enter master mode when the bus has been released.</p> <p>The M_STA bit is cleared automatically after a START condition is sent: writing a '0' to this bit has no effect.</p> |
| 4 | R/W | 0 | <p><b>M_STP</b><br/> <b>Master Mode Stop</b><br/> If M_STP is set to '1' in master mode, a STOP condition is transmitted on the two-wire bus. If the M_STP bit is set to '1' in slave mode, the TWI will behave as if a STOP condition has been received, but no STOP condition will be transmitted on the two-wire bus. If both M_STA and M_STP bits are set, the TWI will first transmit the STOP condition (if in master mode), and then transmit the START condition.</p> <p>The M_STP bit is cleared automatically: writing a '0' to this bit has no effect.</p>                                                                                                                    |
| 3 | R/W | 0 | <p><b>INT_FLAG</b><br/> <b>Interrupt Flag</b><br/> INT_FLAG is automatically set to '1' when any of 28 (out of the possible 29) states is entered (see 'STAT Register' below). The only state that does not set INT_FLAG is state F8h. If the INT_EN bit is set, the interrupt line goes high when IFLG is set to '1'. If the TWI is operating in slave mode, data transfer is suspended when INT_FLAG is set and the low period of the two-wire bus clock line (SCL) is stretched until '0' is written to INT_FLAG. The 2-wire clock line is then released and the interrupt line goes low.</p>                                                                                         |
| 2 | R/W | 0 | <p><b>A_ACK</b><br/> <b>Assert Acknowledge</b><br/> When A_ACK is set to '1', an Acknowledge (low level on SDA) will be sent during the acknowledge clock pulse on the two-wire bus if:<br/> 1. Either the whole of a matching 7-bit slave address or the first or</p>                                                                                                                                                                                                                                                                                                                                                                                                                   |

|     |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |   |   | <p>the second byte of a matching 10-bit slave address has been received.</p> <p>2. The general call address has been received and the GCE bit in the ADDR register is set to '1'.</p> <p>3. A data byte has been received in master or slave mode. 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 is 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 | / | / | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 17.4.5. TWI Status Register

| Offset: 0x10 |            |         | Register Name: TWI_STAT<br>Default Value: 0x0000_00F8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7:0          | R          | 0xF8    | <p>Status Information Byte</p> <p>Code 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 transmitted</p> <p>0x58: Data byte received in master mode, not ACK transmitted</p> <p>0x60: Slave address + Write bit received, ACK transmitted</p> <p>0x68: Arbitration lost in address as master, slave address + Write bit received, ACK transmitted</p> <p>0x70: General Call address received, ACK transmitted</p> <p>0x78: Arbitration lost in address as master, General Call address received, ACK transmitted</p> |

|  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  | 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 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: Last byte transmitted in slave mode, ACK received<br>0xD0: Second Address byte + Write bit transmitted, ACK received<br>0xD8: Second Address byte + Write bit transmitted, ACK not received<br>0xF8: No relevant status information, INT_FLAG=0<br>Others: Reserved |
|--|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 17.4.6. TWI Clock Register

| Offset: 0x14 |            |         | Register Name: TWI_CCR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:7         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6:3          | R/W        | 0       | CLK_M<br><br>CLK_N<br>The two-wire bus is sampled by the TWI at the frequency defined by F0:<br>$F_{amp} = F_0 = F_{in} / 2^{CLK\_N}$<br><br>The TWI OSCL output frequency, in master mode, is F1 / 10:<br>$F_1 = F_0 / (CLK\_M + 1)$<br>$F_{oscl} = F_1 / 10 = F_{in} / (2^{CLK\_N} * (CLK\_M + 1) * 10)$<br>For Example:<br>$F_{in} = 48\text{Mhz}$ (APB clock input)<br>For 400kHz full speed 2Wire, CLK_N = 2, CLK_M=2<br>$F_0 = 48\text{M} / 2^2 = 12\text{Mhz}$ , $F_1 = F_0 / (10 * (2+1)) = 0.4\text{Mhz}$<br><br>For 100Khz standard speed 2Wire, CLK_N=2, CLK_M=11<br>$F_0 = 48\text{M} / 2^2 = 12\text{Mhz}$ , $F_1 = F_0 / (10 * (11+1)) = 0.1\text{Mhz}$ |
| 2:0          | R/W        | 0       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

#### 17.4.7. TWI Soft Reset Register

| Offset: 0x18 |            |         | Register Name: TWI_SRST<br>Default Value: 0x0000_0000                                                     |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                               |
| 31:1         | /          | /       | /                                                                                                         |
| 0            | R/W        | 0       | Soft Reset<br>Write '1' to this bit to reset the TWI and clear to '0' when complete Soft Reset operation. |

#### 17.4.8. TWI Enhance Feature Register

| Offset: 0x1C |            |         | Register Name: TWI_EFR<br>Default Value: 0x0000_0000                                                                                                                                                                                            |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                     |
| 31:2         | /          | /       | /                                                                                                                                                                                                                                               |
| 0:1          | R/W        | 0       | Data Byte follow Read Command Control<br>No Data Byte to be written after read command<br>Only 1 byte data to be written after read command<br>2 bytes data can be written after read command<br>3 bytes data can be written after read command |

#### 17.4.9. TWI Line Control Register

| Offset: 0x20 |            |         | Register Name: TWI_LCR<br>Default Value: 0x0000_003a                                                                                                                                               |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                        |
| 31:6         | /          | /       | /                                                                                                                                                                                                  |
| 5            | R          | 1       | Current state of TWI_SCL<br>0 – low<br>1 - high                                                                                                                                                    |
| 4            | R          | 1       | Current state of TWI_SDA<br>0 – low<br>1 - high                                                                                                                                                    |
| 3            | R/W        | 1       | TWI_SCL line state control bit<br>When line control mode is enabled (bit[2] set), value of this bit decide the output level of TWI_SCL<br>0 – output low level<br>1 – output high level            |
| 2            | R/W        | 0       | TWI_SCL line state control enable<br>When this bit is set, the state of TWI_SCL is controlled by the value of bit[3].<br>0-disable TWI_SCL line control mode<br>1-enable TWI_SCL line control mode |
| 1            | R/W        | 1       | TWI_SDA line state control bit<br>When line control mode is enabled (bit[0] set), value of this bit                                                                                                |

|   |     |   |                                                                                                                                                                                                    |
|---|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |   | decides the output level of TWI_SDA<br>0 – output low level<br>1 – output high level                                                                                                               |
| 0 | R/W | 0 | 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 |

#### 17.4.10. TWI DVFS Control Register

| Offset: 0x24 |            |         | Register Name: TWI_DVFSCR<br>Default Value: 0x0000_0000                                            |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                        |
| 31:2         | /          | /       | /                                                                                                  |
| 2            | R/W        | 0       | CPU and DVFS BUSY set priority select<br>0: CPU has higher priority<br>1: DVFS has higher priority |
| 1            | R/W        | 0       | CPU Busy set                                                                                       |
| 0            | R/W        | 0       | DVFS Busy set                                                                                      |

Notes: This register is only implemented in TWI0.

### 17.5. TWI Controller Special Requirement

#### 17.5.1. TWI Pin List

| Port Name | Width | Direction | Description          |
|-----------|-------|-----------|----------------------|
| TWI_SCL   | 1     | IN/OUT    | TWI Clock line       |
| TWI_SDA   | 1     | IN/OUT    | TWI Serial Data line |

#### 17.5.2. TWI Controller Operation

There are four operation modes on the two-wire bus which dictates the communications method: Master Transmit, Master Receive, Slave Transmit and Slave Receive. In general, CPU host controls TWI by writing commands and data to its registers. The TWI interrupts the CPU host for the attention each time a byte transfer is done or a START/STOP condition is detected. The CPU host can also poll the status register for current status if the interrupt mechanism is not disabled by the CPU host.

When the CPU host wants to start a bus transfer, it initiates a bus START to enter the master mode by setting IM\_STA bit in the 2WIRE\_CNTR register to high (before it must be low). The TWI will assert INT line and INT\_FLAG to indicate a completion for the START condition and each consequent byte transfer. At each interrupt, the micro-processor needs to check the 2WIRE\_STAT register for current status. A transfer has to be concluded with STOP condition by setting M\_STP bit high.

In Slave Mode, the TWI also constantly samples the bus and look for its own slave address during addressing cycles. Once a match is found, it is addressed and interrupts the CPU host with the corresponding status. Upon request, the CPU host should read the status, read/write 2WIRE\_DATA data register, and set the 2WIRE\_CNTR control register. After each byte transfer, a slave device

always halt the operation of remote master by holding the next low pulse on SCL line until the microprocessor responds to the status of previous byte transfer or START condition.

## 18. Serial Peripheral Interface (SPI)

### 18.1. Overview

The Serial Peripheral Interface (SPI) allows rapid data communication with less software interrupts. This module contains one 8x64 receiver buffer (RXFIFO) and one 8x64 transmit buffer (TXFIFO). It can work in two modes: Master mode and Slave mode.

It features:

- Full-duplex synchronous serial interface
- Configurable Master/Slave
- Maximum four chip select to multiple peripherals
- 8x64 FIFO for data transmit and receive
- Configurable Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK)
- Support Dedicated DMA

### 18.2. SPI Timing Diagram

The SPI master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

During Phase 0, Polarity 0 and Phase 1, Polarity 1 operations, output data changes on the falling clock edge and input data is shifted in on the rising edge.

During Phase 1, Polarity 0 and Phase 0, Polarity 1 operations, output data changes on the rising edges of the clock and is shifted in on falling edges.

The POL defines the signal polarity when SPI\_SCLK is in idle state. The SPI\_SCLK is high level when POL is '1' and it is low level when POL is '0'. The PHA decides whether the leading edge of SPI\_SCLK is used to setup or sample data. The leading edge is used to setup data when PHA is '1' and to sample data when PHA is '0'. The four modes are listed below:

| SPI Mode | POL | PHA | Leading Edge    | Trailing Edge   |
|----------|-----|-----|-----------------|-----------------|
| 0        | 0   | 0   | Rising, Sample  | Falling, Setup  |
| 1        | 0   | 1   | Rising, Setup   | Falling, Sample |
| 2        | 1   | 0   | Falling, Sample | Rising, Setup   |
| 3        | 1   | 1   | Falling, Setup  | Rising, Sample  |



Figure18-1 SPI Phase 0 Timing Diagram



Figure 18-2 SPI Phase 1 Timing Diagram

### 18.3. SPI Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI0        | 0x01C05000   |
| SPI1        | 0x01C06000   |
| SPI2        | 0x01C17000   |

| Register Name | Offset | Description                     |
|---------------|--------|---------------------------------|
| SPI_RXDATA    | 0x00   | SPI RX Data Register            |
| SPI_TXDATA    | 0x04   | SPI TX Data Register            |
| SPI_CTL       | 0x08   | SPI Control Register            |
| SPI_INTCTL    | 0x0C   | SPI Interrupt Control Register  |
| SPI_ST        | 0x10   | SPI Status Register             |
| SPI_DMACTL    | 0x14   | SPI DMA Control Register        |
| SPI_WAIT      | 0x18   | SPI Wait Clock Counter Register |

|              |      |                                 |
|--------------|------|---------------------------------|
| SPI_CCTL     | 0x1C | SPI Clock Rate Control Register |
| SPI_BC       | 0x20 | SPI Burst Counter Register      |
| SPI_TC       | 0x24 | Spi Transmit Counter Register   |
| SPI_FIFO_STA | 0x28 | SPI FIFO Status Register        |

## 18.4. SPI Register Description

### 18.4.1. SPI RX Data Register

| Offset: 0x00 |            |         | Register Name: SPI_RXDATA<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:0         | R          | 0       | Receive Data<br><br>In 8-bits SPI bus width, this register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are words in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In half-word accessing method, the two SPI bursts are returned and the RXFIFO depth decreases by 2. In word accessing method, the four SPI bursts are returned and the RXFIFO depth decreases by 4. |

### 18.4.2. SPI TX Data Register

| Offset: 0x04 |            |         | Register Name: SPI_TXDATA<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|---------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                             |
| 31:0         | W          | 0       | Transmit Data                                           |

### 18.4.3. SPI Control Register

| Offset: 0x08 |            |         | Register Name: SPI_CTL<br>Default Value: 0x0002_001C                                                                                                                                                                                                                                                                                                                               |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                        |
| 31:20        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                  |
| 19           | R/W        | 0       | Master Sample Data Control<br><br>Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.<br>1 – delay internal read sample point<br>0 – normal operation, do not delay internal read sample point |
| 18           | R/W        | 0       | Transmit Pause Enable<br><br>In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br>1 – stop transmit data when RXFIFO full<br>0 – normal operation, ignore RXFIFO status                                                                                                                                               |

|       |     |   |                                                                                                                                                                                                                                                                                                          |
|-------|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17    | R/W | 1 | <b>SS_LEVEL</b><br>When control SS signal manually (SPI_CTRL_REG.SS_CTRL==1), set this bit to '1' or '0' to control the level of SS signal.<br>1 – set SS to high<br>0 – set SS to low                                                                                                                   |
| 16    | R/W | 0 | <b>SS_CTRL - SS Output Mode Select</b><br>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTRL_REG.SS_LEVEL (bit [17]) to 1 or 0 to control the level of SS signal.<br>1 – manual output SS<br>0 – automatic output SS |
| 15    | R/W | 0 | <b>Discard Hash Burst</b><br><b>DHB</b><br>In master mode it controls whether discarding unused SPI bursts.<br>0: Receiving all SPI bursts in BC period<br>1: Discard unused SPI bursts, only fetching the SPI bursts during dummy burst period. The bursts number is specified by WTC.                  |
| 14    | R/W | 0 | <b>DDB</b><br><b>Dummy Burst Type</b><br>0: The bit value of dummy SPI burst is zero<br>1: The bit value of dummy SPI burst is one                                                                                                                                                                       |
| 13:12 | R/W | 0 | <b>SS</b><br><b>SPI Chip Select</b><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>Notes: This two bits can't be configured for SPI1 Engine.                 |
| 11    | R/W | 0 | <b>RPSM</b><br><b>Rapids Mode Select</b><br>Select Rapids operation mode for high speed read.<br>0: Normal read mode<br>1: Rapids read mode                                                                                                                                                              |
| 10    | R/W | 0 | <b>XCH</b><br><b>Exchange Burst</b><br>In master mode it is used to start to SPI burst.<br>0: Idle<br>1: Initiates exchange. After finishing the SPI bursts transfer specified by BC, this bit is cleared to zero by SPI Controller.                                                                     |
| 9     | R/W | 0 | <b>RXFIFO Reset</b>                                                                                                                                                                                                                                                                                      |

|   |     |   |                                                                                                                                                                                  |
|---|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |   | Write '1' to reset the control portion of the receiver FIFO and treats the FIFO as empty.<br>It is 'self-clearing'. It is not necessary to clear this bit.                       |
| 8 | R/W | 0 | TXFIFO Reset<br>Write '1' to reset the control portion of the transmit FIFO and treats the FIFO as empty.<br>It is 'self-clearing'. It is not necessary to clear this bit.       |
| 7 | R/W | 0 | SSCTL<br>In master mode, this bit selects the output wave form for the SPI_SSx signal.<br>0: SPI_SSx remains asserted between SPI bursts<br>1: Negate SPI_SSx between SPI bursts |
| 6 | R/W | 0 | LMTF<br>LSB/ MSB Transfer First select<br>0: MSB first<br>1: LSB first                                                                                                           |
| 5 | R/W | 0 | DMAM<br>DMA mode control<br>0: normal dma<br>1: dedicate dma                                                                                                                     |
| 4 | R/W | 1 | SSPOL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)                                                      |
| 3 | R/W | 1 | POL<br>SPI Clock Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)                                                                     |
| 2 | R/W | 1 | PHA<br>SPI Clock/Data Phase Control<br>0: Phase 0 (Leading edge for sample data)<br>1: Phase 1 (Leading edge for setup data)                                                     |
| 1 | R/W | 0 | MODE<br>SPI Function Mode Select<br>0: Slave Mode<br>1: Master Mode                                                                                                              |
| 0 | R/W | 0 | EN<br>SPI Module Enable Control<br>0: Disable<br>1: Enable                                                                                                                       |

#### 18.4.4. SPI Interrupt Control Register

|              |                           |
|--------------|---------------------------|
| Offset: 0x0C | Register Name: SPI_INTCTL |
|--------------|---------------------------|

|       |            |         | Default Value: 0x0000_0000                                                                                    |
|-------|------------|---------|---------------------------------------------------------------------------------------------------------------|
| Bit   | Read/Write | Default | Description                                                                                                   |
| 31:18 | /          | /       | /                                                                                                             |
| 17    | R/W        | 0       | SSI Interrupt Enable<br>Chip Select Signal (SSx) from valid state to invalid state<br>0: Disable<br>1: Enable |
| 16    | R/W        | 0       | Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                |
| 15    | /          | /       | /                                                                                                             |
| 14    | R/W        | 0       | TXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable                                                  |
| 13    | R/W        | 0       | TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable                                                  |
| 12    | R/W        | 0       | TX FIFO 3/4 Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                 |
| 11    | R/W        | 0       | TX FIFO 1/4 Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                 |
| 10    | R/W        | 0       | TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable                                                      |
| 9     | R/W        | 0       | TX FIFO Half Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                |
| 8     | R/W        | 0       | TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                     |
| 7     | /          | /       | /                                                                                                             |
| 6     | R/W        | 0       | RXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable                                                  |
| 5     | R/W        | 0       | RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable                                                  |
| 4     | R/W        | 0       | RXFIFO 3/4 Full Interrupt Enable<br>0: Disable<br>1: Enable                                                   |
| 3     | R/W        | 0       | RX FIFO 1/4 Full Interrupt Enable                                                                             |

|   |     |   |                                                               |
|---|-----|---|---------------------------------------------------------------|
|   |     |   | 0: Disable<br>1: Enable                                       |
| 2 | R/W | 0 | RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable      |
| 1 | R/W | 0 | RX FIFO Half Full Interrupt Enable<br>0: Disable<br>1: Enable |
| 0 | R/W | 0 | RX FIFO Ready Interrupt Enable<br>0: Disable<br>1: Enable     |

#### 18.4.5. SPI Interrupt Status Register

| Offset: 0x10 |            |         | Register Name: SPI_INT_STA<br>Default Value: 0x0000_1B00                                                                                                                                                                                                                                                                                                   |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                |
| 31           | R          | 0       | Clear interrupt busy flag<br>0: clearing interrupt is done<br>1: clearing interrupt is busy                                                                                                                                                                                                                                                                |
| 30:24        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 23:20        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 19:18        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 17           | R/W        | 0       | SSI<br>SS Invalid Interrupt<br>When SSI is 1, it indicates that SS has changed from valid state to invalid state. Writing 1 to this bit clears it.                                                                                                                                                                                                         |
| 16           | R/W        | 0       | TC<br>Transfer Completed<br>In master mode, it indicates that all bursts specified by BC has been exchanged. In other condition, 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 |
| 15           | /          | /       | /                                                                                                                                                                                                                                                                                                                                                          |
| 14           | R/W        | 0       | TU<br>TXFIFO under run<br>This bit is set when if the TXFIFO is underrun. Writing 1 to this bit clears it.<br>0: TXFIFO is not underrun<br>1: TXFIFO is underrun                                                                                                                                                                                           |
| 13           | R/W        | 0       | TO                                                                                                                                                                                                                                                                                                                                                         |

|    |     |   |                                                                                                                                                                                                                                 |
|----|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |   | <p><b>TXFIFO Overflow</b><br/> This bit is set when the TXFIFO overflows. Writing 1 to this bit clears it.<br/> 0: TXFIFO is not overflow<br/> 1: TXFIFO is overflowed</p>                                                      |
| 12 | R/W | 1 | <p><b>TXFIFO 3/4 empty</b><br/> This bit is set if the TXFIFO is more than 3/4 empty. Writing 1 to this bit clears it.</p>                                                                                                      |
| 11 | R/W | 1 | <p><b>TXFIFO 1/4 empty</b><br/> This bit is set if the TXFIFO is more than 1/4 empty. Writing 1 to this bit clears it.</p>                                                                                                      |
| 10 | R/W | 0 | <p><b>TF</b><br/> <b>TXFIFO Full</b><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>                                                      |
| 9  | R/W | 1 | <p><b>THE</b><br/> <b>TXFIFO Half empty</b><br/> This bit is set if the TXFIFO is more than half empty. Writing 1 to this bit clears it.<br/> 0: TXFIFO holds more than half words<br/> 1: TXFIFO holds half or fewer words</p> |
| 8  | R/W | 1 | <p><b>TE</b><br/> <b>TXFIFO Empty</b><br/> This bit is set if the TXFIFO is empty. Writing 1 to this bit clears it.<br/> 0: TXFIFO contains one or more words.<br/> 1: TXFIFO is empty</p>                                      |
| 7  | /   | / | /                                                                                                                                                                                                                               |
| 6  | R/W | 0 | <p><b>RU</b><br/> <b>RXFIFO Underrun</b><br/> When set, this bit indicates that RXFIFO has underrun. Writing 1 to this bit clears it.</p>                                                                                       |
| 5  | R/W | 0 | <p><b>RO</b><br/> <b>RXFIFO Overflow</b><br/> When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br/> 0: RXFIFO is available.<br/> 1: RXFIFO has overflowed.</p>                         |
| 4  | R/W | 0 | <p><b>RXFIFO 3/4 Full</b><br/> This bit is set when the RXFIFO is 3/4 full. Writing 1 to this bit clears it.<br/> 0: Not 3/4 Full<br/> 1: 3/4 Full</p>                                                                          |

|   |     |   |                                                                                                                                                                                                                                    |
|---|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | R/W | 0 | RXFIFO 1/4 Full<br>This bit is set when the RXFIFO is 1/4 full. Writing 1 to this bit clears it.<br>0: Not 1/4 Full<br>1: 1/4 Full                                                                                                 |
| 2 | R/W | 0 | RF<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                                                                                                           |
| 1 | R/W | 0 | RHF<br>RXFIFO Half Full. This bit is set if the RXFIFO is half full ( $\geq 4$ words in RXFIFO) . Writing 1 to this bit clears it.<br>0: Less than 4 words are stored in RXFIFO.<br>1: Four or more words are available in RXFIFO. |
| 0 | R/W | 0 | RR<br>RXFIFO Ready<br>This bit is set any time there is one or more words stored in RXFIFO ( $\geq 1$ words). Writing 1 to this bit clears it.<br>0: No valid data in RXFIFO<br>1: More than 1 word in RXFIFO                      |

#### 18.4.6. SPI DMA Control Register

| Offset: 0x14 |            |         | Register Name: SPI_DMACTL<br>Default Value: 0x0000_0000                                                                                                                    |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                |
| 31:13        | /          | /       | /                                                                                                                                                                          |
| 12           | R/W        | 0       | TXFIFO3/4 Empty DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                              |
| 11           | R/W        | 0       | TXFIFO 1/4 Empty DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                             |
| 10           | R/W        | 0       | TXFIFO Not Full DMA Request Enable<br>When enabled, if more than one free room for burst, DMA request is asserted, otherwise, it's de-asserted.<br>0: Disable<br>1: Enable |
| 9            | R/W        | 0       | TXFIFO Half Empty DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                            |
| 8            | R/W        | 0       | TXFIFO Empty DMA Request Enable<br>0: Disable                                                                                                                              |

|     |     |   |                                                                                                                                                            |
|-----|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 1: Enable                                                                                                                                                  |
| 7:5 | /   | / | /                                                                                                                                                          |
| 4   | R/W | 0 | RXFIFO 3/4 Full DMA Request Enable<br>This bit enables/disables the RXFIFO 3/4 Full DMA Request.<br>0: Disable<br>1: Enable                                |
| 3   | R/W | 0 | RXFIFO 1/4 Full DMA Request Enable<br>This bit enables/disables the RXFIFO 1/4 Full DMA Request.<br>0: Disable<br>1: Enable                                |
| 2   | R/W | 0 | RXFIFO Full DMA Request Enable<br>This bit enables/disables the RXFIFO Half Full DMA Request.<br>0: Disable<br>1: Enable                                   |
| 1   | R/W | 0 | RXFIFO Half Full DMA Request Enable<br>This bit enables/disables the RXFIFO Half Full DMA Request.<br>0: Disable<br>1: Enable                              |
| 0   | R/W | 0 | RXFIFO Ready Request Enable<br>This bit enables/disables the RXFIFO Ready DMA Request when one or more than one words in RXFIFO<br>0: Disable<br>1: Enable |

#### 18.4.7. SPI Wait Clock Register

|              |            |         |                                                                                                                                                                                                                                                                              |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x18 |            |         | Register Name: SPI_WAIT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                        |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                  |
| 31:16        | /          | /       | /                                                                                                                                                                                                                                                                            |
| 15:0         | R/W        | 0       | WCC<br>Wait Clock Counter (In Master mode)<br>These bits control the number of wait states to be inserted in data transfers. The SPI module counts SPI_SCLK by WCC for delaying next word data transfer.<br>0: No wait states inserted<br>N: N SPI_SCLK wait states inserted |

#### 18.4.8. SPI Clock Control Register

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0x1C |            |         | Register Name: SPI_CCTL<br>Default Value: 0x0000_0002 |
| Bit          | Read/Write | Default | Description                                           |
| 31:13        | /          | /       | /                                                     |
| 12           | R/W        | 0       | DRS                                                   |

|      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | Divide Rate Select (Master Mode Only)<br>0: Select Clock Divide Rate 1<br>1: Select Clock Divide Rate 2                                                                                                                                                                                                                                                                                                                                                            |
| 11:8 | R/W | 0   | CDR1<br>Clock Divide Rate 1 (Master Mode Only)<br>This field selects the baud rate of the SPI_SCLK based on a division of the AHB_CLK. These bits allow SPI to synchronize with different external SPI devices. The max frequency is one quarter of AHB_CLK. The divide ratio is determined according to the following table using the equation: $2^{(n+1)}$ . The SPI_SCLK is determined according to the following equation: $SPI\_CLK = AHB\_CLK / 2^{(n+1)}$ . |
| 7:0  | R/W | 0x2 | CDR2<br>Clock Divide Rate 2 (Master Mode Only)<br>The SPI_SCLK is determined according to the following equation:<br>$SPI\_CLK = AHB\_CLK / (2^{(n + 1)})$ .                                                                                                                                                                                                                                                                                                       |

#### 18.4.9. SPI Burst Counter Register

| Offset: 0x20 |            |         | Register Name: SPI_BC<br>Default Value: 0x0000_0000                                                                                   |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                           |
| 31:24        | /          | /       | /                                                                                                                                     |
| 23:0         | R/W        | 0       | BC<br>Burst Counter<br>In master mode, this field specifies the total burst number.<br>0: 0 burst<br>1: 1 burst<br>...<br>N: N bursts |

#### 18.4.10. SPI Transmit Counter Register

| Offset: 0x24 |            |         | Register Name: SPI_TC<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                           |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                   |
| 31:24        | /          | /       | /                                                                                                                                                                                                                                                                                                             |
| 23:0         | R/W        | 0       | WTC<br>Write Transmit Counter<br>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy burst. For saving bus bandwidth, the dummy burst (all zero bits or all one bits) is sent by SPI Controller automatically.<br>0: 0 burst<br>1: 1 burst |

|  |  |  |             |
|--|--|--|-------------|
|  |  |  | ...         |
|  |  |  | N: N bursts |

#### 18.4.11. SPI FIFO Status Register

|              |            |         |                                                                                                                                                                                     |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x28 |            |         | Register Name: SPI_FIFO_STA<br>Default Value: 0x0000_0000                                                                                                                           |
| Bit          | Read/Write | Default | Description                                                                                                                                                                         |
| 31:25        | /          | /       | /                                                                                                                                                                                   |
|              |            |         | 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>...<br>63: 63 bytes in TXFIFO<br>64: 64 bytes in TXFIFO |
| 22:16        | R          | 0x0     |                                                                                                                                                                                     |
| 15:7         | /          | /       | /                                                                                                                                                                                   |
|              |            |         | 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>...<br>63: 63 bytes in RXFIFO<br>64: 64 bytes in RXFIFO |
| 6:0          | R          | 0x0     |                                                                                                                                                                                     |

### 18.5. SPI Special Requirement

#### 18.5.1. SPI Pin List

The direction of SPI pin is different in two work modes: Master Mode and Slave Mode.

| Port Name   | Width | Direction(M) | Direction(S) | Description                               |
|-------------|-------|--------------|--------------|-------------------------------------------|
| SPI_SCLK    | 1     | OUT          | IN           | SPI Clock                                 |
| SPI_MOSI    | 1     | OUT          | IN           | SPI Master Output Slave Input Data Signal |
| SPI_MISO    | 1     | IN           | OUT          | SPI Master Input Slave Output Data Signal |
| SPI_SS[3:0] | 4     | OUT          | IN           | SPI Chip Select Signal                    |

Notes: SPI0 module has four chip select signals and SPI1 module has only one chip select signal out of pin saving consideration.

#### 18.5.2. SPI Module Clock Source and Frequency

The SPI module uses two clock sources: AHB\_CLK and SPI\_CLK. The SPI\_SCLK can in the range from 3KHz to 100MHz and AHB\_CLK>= 2x SPI\_SCLK.

| Clock Name | Description                               | Requirement           |
|------------|-------------------------------------------|-----------------------|
| AHB_CLK    | AHB Bus Clock, as the clock source of SPI | AHB_CLK >= 2xSPI_SCLK |

|         | module                 |  |
|---------|------------------------|--|
| SPI_CLK | SPI Serial Input Clock |  |

# 19. UART

## 19.1. Overview

The Universal Asynchronous Receiver/Transmitter (UART) interface is used for serial communication with a peripheral, modem (Data Carrier Equipment, DCE) or data set. Data is written from a master (CPU) over the APB bus to the UART and it is converted to serial form and transmitted to the destination device. Serial data is also received by the UART and stored for the master (CPU) to read back.

The UART contains registers to control the character length, baud rate, parity generation/checking, and interrupt generation. Although there is only one interrupt output signal from the UART, there are several prioritized interrupt types responsible for its assertion. Each of the interrupt types can be separately enabled and disabled with the control registers.

The UART has 16450 and 16550 modes of operation, which are compatible with a range of standard software drivers. In 16550 mode, transmit and receive operations are both buffered by FIFOs. In 16450 mode, these FIFOs are disabled.

The UART supports word lengths from five to eight bits, an optional parity bit and 1, 1.5 or 2 stop bits, and is fully programmable by an AMBA APB CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. Eight modem control lines and a diagnostic loop-back mode are provided.

Interrupts can be generated for a range of TX Buffer/FIFO, RX Buffer/FIFO, Modem Status and Line Status conditions.

The UART features:

- Compatible with industry-standard 16550 UARTs
- 64-Bytes Transmit And Receive Data Fifos
- DMA Controller Interface
- Software/ Hardware Flow Control
- Programmable Transmit Holding Register Empty Interrupt
- Interrupt Support For Fifos, Status Change

## 19.2. UART Timing Diagram



Figure 19-1 UART Serial Data Format



Figure 19-2 Serial IrDA Data Format

### 19.3. UART Register List

There are 4 UART controllers. UART1 has full modem control signals, including RTS, CTS, DTR, DSR, DCD and RING signal. UART2 and UART3 have two data flow control singals, including RTS and CTS. Other UART controllers have only two data signals, including DIN and DOUT. All UART controllers can be configured as Serial IrDA.

| Module Name | Base Address |
|-------------|--------------|
| UART0       | 0x01C28000   |
| UART1       | 0x01C28400   |
| UART2       | 0x01C28800   |
| UART3       | 0x01C28C00   |

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| UART_RBR      | 0x00   | UART Receive Buffer Register     |
| UART_THR      | 0x00   | UART Transmit Holding Register   |
| UART_DLL      | 0x00   | UART Divisor Latch Low Register  |
| UART_DLH      | 0x04   | UART Divisor Latch High Register |
| UART_IER      | 0x04   | UART Interrupt Enable Register   |
| UART_IIR      | 0x08   | UART Interrupt Identity Register |
| UART_FCR      | 0x08   | UART FIFO Control Register       |
| UART_LCR      | 0x0C   | UART Line Control Register       |
| UART_MCR      | 0x10   | UART Modem Control Register      |
| UART_LSR      | 0x14   | UART Line Status Register        |
| UART_MSR      | 0x18   | UART Modem Status Register       |
| UART_SCH      | 0x1C   | UART Scratch Register            |
| UART_USR      | 0x7C   | UART Status Register             |
| UART_TFL      | 0x80   | UART Transmit FIFO Level         |
| UART_RFL      | 0x84   | UART_RFL                         |
| UART_HALT     | 0xA4   | UART Halt TX Register            |

## 19.4. UART Register Description

### 19.4.1. UART Receiver Buffer Register

| Offset: 0x00 |            |         | Register Name: UART_RBR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7:0          | R          | 0       | <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 the Line Status Register (LCR) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, the data already in the FIFO is preserved, but all incoming data are lost and an overrun error occurs.</p> |

### 19.4.2. UART Transmit Holding Register

| Offset: 0x00 |            |         | Register Name: UART_THR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7:0          | W          | 0       | <p><b>THR</b><br/> <b>Transmit Holding Register</b><br/> Data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] = 1) and THRE is set, 16 number of characters of data may be written to the THR before the FIFO is full. Any attempt to write data when the FIFO is full results the write data lost.</p> |

### 19.4.3. UART Divisor Latch Low Register

| Offset: 0x00 |            |         | Register Name: UART_DLL<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|-------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                           |
| 31:8         | /          | /       | /                                                     |

|     |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | DLL<br><br>Divisor Latch Low<br><br>Lower 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).<br><br>The output baud rate equals to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).<br><br>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLL is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data. |
| 7:0 | R/W | 0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 19.4.4. UART Divisor Latch High Register

| Offset: 0x04 |            |         | Register Name: UART_DLH<br><br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|              |            |         | DLH<br><br>Divisor Latch High<br><br>Upper 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).<br><br>The output baud rate equals to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).<br><br>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data. |
| 7:0          | R/W        | 0       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### 19.4.5. UART Interrupt Enable Register

| Offset: 0x04 |            |         | Register Name: UART_IER<br><br>Default Value: 0x0000_0000                                                                    |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                  |
| 31:8         | /          | /       | /                                                                                                                            |
| 7            | R/W        |         | PTIME<br><br>Programmable THRE Interrupt Mode Enable<br><br>This is used to enable/disable the generation of THRE Interrupt. |

|     |     |   |                                                                                                                                                                                                                                                                                               |
|-----|-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 0: Disable<br>1: Enable                                                                                                                                                                                                                                                                       |
| 6:4 | /   | / | /                                                                                                                                                                                                                                                                                             |
| 3   | R/W | 0 | 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                                                                                                  |
| 2   | R/W | 0 | 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                                                                                          |
| 1   | R/W | 0 | 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                                                          |
| 0   | R/W | 0 | 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 interrupts.<br>0: Disable<br>1: Enable |

#### 19.4.6. UART Interrupt Identity Register

| Offset: 0x08 |            |         | Register Name: UART_IIR<br>Default Value: 0x0000_0000                                                                           |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                     |
| 31:8         | /          | /       | /                                                                                                                               |
| 7:6          | R          | 0       | FEFLAG<br>FIFOs Enable Flag<br>This is used to indicate whether the FIFOs are enabled or disabled.<br>00: Disable<br>11: Enable |
| 5:4          | /          | /       | /                                                                                                                               |
| 3:0          | R          | 0x1     | IID                                                                                                                             |

|  |  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p><b>Interrupt ID</b></p> <p>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>0100: received data available</li> <li>0110: receiver line status</li> <li>0111: busy detect</li> <li>1100: character timeout</li> </ul> <p>Bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt.</p> |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

| <b>Interrupt ID</b> | <b>Priority Level</b> | <b>Interrupt Type</b>           | <b>Interrupt Source</b>                                                                                                                   | <b>Interrupt Reset</b>                                                                                                                                                                         |
|---------------------|-----------------------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0001                | -                     | None                            | None                                                                                                                                      | -                                                                                                                                                                                              |
| 0110                | Highest               | Receiver Line Status            | Overrun/parity/ framing errors or break interrupt                                                                                         | Reading the line status register                                                                                                                                                               |
| 0100                | Second                | 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                | Second                | Character Timeout Indication    | No characters in or out of the RCVR FIFO during the last 4 character times and there is at least 1character in it during This time        | Reading the receiver buffer register                                                                                                                                                           |
| 0010                | Third                 | Transmit Holding Register Empty | Transmitter holding register empty (Program THRE Mode disabled) or XMIT FIFO at or below threshold (Program THRE Mode enabled)            | Reading the IIR register (if source of interrupt); or, writing into THR (FIFOs or THRE Mode not selected or disabled) or XMIT FIFO above threshold (FIFOs and THRE Mode selected and enabled). |
| 0000                | Fourth                | Modem Status                    | Clear to send or data set ready or ring indicator or data carrier detect. Note that if auto flow control mode is enabled, a change in CTS | Reading the Modem status Register                                                                                                                                                              |

|      |       |                        |                                                                                                                                      |                                  |
|------|-------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
|      |       |                        | (that is, DCTS set) does not cause an interrupt.                                                                                     |                                  |
| 0111 | Fifth | 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 |

#### 19.4.7. UART FIFO Control Register

| Offset: 0x08 |            |         | Register Name: UART_FCR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                 |  |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 31:8         | /          | /       | RT<br>RCVR Trigger<br>This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. In auto flow control mode it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation.<br>00: 1 character in the FIFO<br>01: FIFO ¼ full<br>10: FIFO ½ full<br>11: FIFO-2 less than full |  |
| 7:6          | W          | 0       | TFT<br>TX Empty Trigger<br>Writes have no effect when THRE_MODE_USER = Disabled. This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. It also determines when the dma_tx_req_n signal is asserted when in certain modes of operation.<br>00: FIFO empty<br>01: 2 characters in the FIFO<br>10: FIFO ¼ full<br>11: FIFO ½ full                                         |  |
| 5:4          | W          | 0       | DMAM<br>DMA Mode<br>0: Mode 0<br>1: Mode 1                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 2            | W          | 0       | XFIFOR<br>XMIT FIFO Reset<br>This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request.                                                                                                                                                                                                                                                                              |  |

|   |   |   |                                                                                                                                                                                                                                             |
|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | It is 'self-clearing'. It is not necessary to clear this bit.                                                                                                                                                                               |
| 1 | W | 0 | <p>RFIFOR</p> <p>RCVR FIFO Reset</p> <p>This resets the control portion of the receive FIFO and treats the FIFO as empty. This also de-asserts the DMA RX request.</p> <p>It is 'self-clearing'. It is not necessary to clear this bit.</p> |
| 0 | W | 0 | <p>FIFOE</p> <p>Enable FIFOs</p> <p>This enables/disables the transmit (XMIT) and receive (RCVR) FIFOs. Whenever the value of this bit is changed both the XMIT and RCVR controller portion of FIFOs is reset.</p>                          |

#### 19.4.8. UART Line Control Register

| Offset: 0x0C |            |         | Register Name: UART_LCR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7            | R/W        | 0       | <p>DLAB</p> <p>Divisor Latch Access Bit</p> <p>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial baud rate setup in order to access other registers.</p> <p>0: Select RX Buffer Register (RBR) / TX Holding Register(THR) and Interrupt Enable Register (IER)</p> <p>1: Select Divisor Latch LS Register (DLL) and Divisor Latch MS Register (DLM)</p> |
| 6            | R/W        | 0       | <p>BC</p> <p>Break Control Bit</p> <p>This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE = Enabled and active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low.</p>         |
| 5            | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4            | R/W        | 0       | <p>EPS</p> <p>Even Parity Select</p> <p>It is writeable only when UART is not busy (USR[0] is zero) and always writable readable. This is used to select between even and</p>                                                                                                                                                                                                                                                                                                                                                                             |

|     |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | odd parity, when parity is enabled (PEN set to one).<br>0: Odd Parity<br>1: Even Parity                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3   | R/W | 0 | PEN<br><br>Parity Enable<br><br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.<br>0: parity disabled<br>1: parity enabled                                                                                                                                                                                                                                                                                                                                                    |
| 2   | R/W | 0 | STOP<br><br>Number of stop bits<br><br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to zero, one stop bit is transmitted in the serial data. If set to one and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.<br>0: 1 stop bit<br>1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit |
| 1:0 | R/W | 0 | DLS<br><br>Data Length Select<br><br>It is writeable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of data bits per character that the peripheral transmits and receives. The number of bit that may be selected areas follows:<br>00: 5 bits<br>01: 6 bits<br>10: 7 bits<br>11: 8 bits                                                                                                                                                                                                                                                                                                     |

#### 19.4.9. UART Modem Control Register

|              |            |         |                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------|
| Offset: 0x10 |            |         | Register Name: UART_MCR<br><br>Default Value: 0x0000_0000                            |
| Bit          | Read/Write | Default | Description                                                                          |
| 31:7         | /          | /       | /                                                                                    |
| 6            | R/W        | 0       | SIRE<br><br>SIR Mode Enable<br>0: IrDA SIR Mode disabled<br>1: IrDA SIR Mode enabled |

|   |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5 | R/W | 0 | <b>AFCE</b><br>Auto Flow Control Enable<br>When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled.<br>0: Auto Flow Control Mode disabled<br>1: Auto Flow Control Mode enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4 | R/W | 0 | <b>LOOP</b><br>Loop Back Mode<br>0: Normal Mode<br>1: Loop Back Mode<br>This is used to put the UART into a diagnostic mode for test purposes. If operating in UART mode (SIR_MODE != Enabled or not active, MCR[6] set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally. If operating in infrared mode (SIR_MODE == Enabled AND active, MCR[6] set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.                                                                                                                            |
| 3 | /   | / | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2 | /   | / | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1 | R/W | 0 | <b>RTS</b><br>Request to Send<br>This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] set to zero), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] set to one) and FIFOs enable (FCR[0] set to one), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when MCR[1] is set low.<br>0: rts_n de-asserted (logic 1)<br>1: rts_n asserted (logic 0)<br>Note that in Loopback mode (MCR[4] set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input. |
| 0 | R/W | 0 | DTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

|  |  |  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p><b>Data Terminal Ready</b><br/> This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n.</p> <p>0: dtr_n de-asserted (logic 1)<br/> 1: dtr_n asserted (logic 0)</p> <p>The Data Terminal Ready output is used to inform the modem or data set that the UART is ready to establish communications.</p> <p>Note that in Loopback mode (MCR[4] set to one), the dtr_n output is held inactive high while the value of this location is internally looped back to an input.</p> |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 19.4.10. UART Line Status Register

| Offset: 0x14 |            |         | Register Name: UART_LSR<br>Default Value: 0x0000_0060                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7            | R          | 0       | <p><b>FIFOERR</b><br/> RX Data Error in FIFO</p> <p>When FIFOs are disabled, this bit is always 0. When FIFOs are enabled, this bit is set to 1 when there is at least one PE, FE, or BI in the RX FIFO. It is cleared by a read from the LSR register provided there are no subsequent errors in the FIFO.</p>                                                                                               |
| 6            | R          | 1       | <p><b>TEMT</b><br/> Transmitter Empty</p> <p>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register and the TX Shift Register are empty. If the FIFOs are enabled, this bit is set whenever the TX FIFO and the TX Shift Register are empty. In both cases, this bit is cleared when a byte is written to the TX data channel.</p>                                                |
| 5            | R          | 1       | <p><b>THRE</b><br/> TX Holding Register Empty</p> <p>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register is empty and ready to accept new data and it is cleared when the CPU writes to the TX Holding Register.</p> <p>If the FIFOs are enabled, this bit is set to "1" whenever the TX FIFO is empty and it is cleared when at least one byte is written to the TX FIFO.</p> |
| 4            | R          | 0       | <p><b>BI</b><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 whenever the</p>                                                                                                                                                                                                       |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | <p>serial input, sin, is held in a logic '0' state for longer than the sum of start time + data bits + parity + stop bits.</p> <p>If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of start time + data bits + parity + stop bits. 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 LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.</p>                                                                                                                 |
| 3 | R | 0 | <p>FE</p> <p>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 occurs due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>0: no framing error</p> <p>1:framing error</p> <p>Reading the LSR clears the FE bit.</p> |
| 2 | R | 0 | <p>PE</p> <p>Parity Error</p> <p>This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>0: no parity error</p> <p>1: parity error</p> <p>Reading the LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                                |
| 1 | R | 0 | <p>OE</p> <p>Overrun Error</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | <p>This occurs if a new data character is received before the previous data is read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character is read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.</p> <p>0: no overrun error<br/>1: overrun error</p> <p>Reading the LSR clears the OE bit.</p> |
| 0 | R | 0 | <p>DR<br/>Data Ready</p> <p>This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.</p> <p>0: no data ready<br/>1: data ready</p> <p>This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty in FIFO mode.</p>                                                                                                                                                                                                                                                                             |

#### 19.4.11. UART Modem Status Register

| Offset: 0x18 |            |         | Register Name: UART_MSR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8         | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7            | R          | 0       | <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> |
| 6            | R          | 0       | <p>RI<br/>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 the modem or data set.</p> <p>0: ri_n input is de-asserted (logic 1)<br/>1: ri_n input is asserted (logic 0)</p>  |
| 5            | R          | 0       | <p>DSR<br/>Line State of Data Set Ready</p> <p>This is used to indicate the current state of the modem control line</p>                                                                                                                                                                                                                                                                                  |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | <p>dsr_n. This bit is the complement of dsr_n. When the Data Set Ready input (dsr_n) is asserted it is an indication that the modem or data set is ready to establish communications with UART.</p> <p>0: dsr_n input is de-asserted (logic 1)<br/>     1: dsr_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] set to one), DSR is the same as MCR[0] (DTR).</p>                                                                                                                                                            |
| 4 | R | 0 | <p>CTS<br/>     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)<br/>     1: cts_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS).</p>                                                         |
| 3 | R | 0 | <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 MSR was read.</p> <p>0: no change on dcd_n since last read of MSR<br/>     1: change on dcd_n since last read of MSR</p> <p>Reading the MSR clears the DDCD bit.</p> <p>Note: If the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDCD bit is set when the reset is removed if the dcd_n signal remains asserted.</p> |
| 2 | R | 0 | <p>TERI<br/>     Trailing Edge Ring Indicator</p> <p>This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR is read.</p> <p>0: no change on ri_n since last read of MSR<br/>     1: change on ri_n since last read of MSR</p> <p>Reading the MSR clears the TERI bit.</p>                                                                                                                                                                       |
| 1 | R | 0 | <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 MSR was read.</p> <p>0: no change on dsr_n since last read of MSR<br/>     1: change on dsr_n since last read of MSR</p> <p>Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4]</p>                                                                                                                                                                                                 |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | = 1), DDSR reflects changes on MCR[0] (DTR).<br><br>Note: If the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.                                                                                                                                                                                                                                                                                                                             |
| 0 | R | 0 | DCTS<br><br>Delta Clear to Send<br><br>This is used to indicate that the modem control line cts_n has changed since the last time the MSR was read.<br>0: no change on ctsdsr_n since last read of MSR<br>1: change on ctsdsr_n since last read of MSR<br><br>Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS).<br><br>Note: If the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), the DCTS bit is set when the reset is removed if the cts_n signal remains asserted. |

#### 19.4.12. UART Scratch Register

|              |            |         |                                                                                                                                   |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x1C |            |         | Register Name: UART_SCH<br><br>Default Value: 0x0000_0000                                                                         |
| Bit          | Read/Write | Default | Description                                                                                                                       |
| 31:8         | /          | /       | /                                                                                                                                 |
| 7:0          | R/W        | 0       | Scratch Register<br><br>This register is used by programmers as a temporary storage space. It has no defined purpose in the UART. |

#### 19.4.13. UART Status Register

|              |            |         |                                                                                                                                                                                                                                          |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x7C |            |         | Register Name: UART_USR<br><br>Default Value: 0x0000_0006                                                                                                                                                                                |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                              |
| 31:5         | /          | /       | /                                                                                                                                                                                                                                        |
| 4            | R          | 0       | RFF<br><br>Receive FIFO Full<br><br>This is used to indicate that the receive FIFO is completely full.<br>0: Receive FIFO not full<br>1: Receive FIFO Full<br><br>This bit is cleared when the RX FIFO is no longer full.                |
| 3            | R          | 0       | RFNE<br><br>Receive FIFO Not Empty<br><br>This is used to indicate that the receive FIFO contains one or more entries.<br>0: Receive FIFO is empty<br>1: Receive FIFO is not empty<br><br>This bit is cleared when the RX FIFO is empty. |

|   |   |   |                                                                                                                                                                                                                                                                                              |
|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 | R | 1 | <p><b>TFE</b><br/>         Transmit FIFO Empty<br/>         This is used to indicate that the transmit FIFO is completely empty.<br/>         0: Transmit FIFO is not empty<br/>         1: Transmit FIFO is empty<br/>         This bit is cleared when the TX FIFO is no longer empty.</p> |
| 1 | R | 1 | <p><b>TFNF</b><br/>         Transmit FIFO Not Full<br/>         This is used to indicate that the transmit FIFO is not full.<br/>         0: Transmit FIFO is full<br/>         1: Transmit FIFO is not full<br/>         This bit is cleared when the TX FIFO is full.</p>                  |
| 0 | R | 0 | <p><b>BUSY</b><br/>         UART Busy Bit<br/>         0: Idle or inactive<br/>         1: Busy</p>                                                                                                                                                                                          |

#### 19.4.14. UART Transmit FIFO Level Register

|              |            |         |                                                                                                         |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------|
| Offset: 0x80 |            |         | Register Name: UART_TFL<br>Default Value: 0x0000_0000                                                   |
| Bit          | Read/Write | Default | Description                                                                                             |
| 31:7         | /          | /       | /                                                                                                       |
| 6:0          |            |         | <p>Transmit FIFO Level<br/>         This indicates the number of data entries in the transmit FIFO.</p> |

#### 19.4.15. UART Receive FIFO Level Register

|              |            |         |                                                                                                       |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------|
| Offset: 0x84 |            |         | Register Name: UART_RFL<br>Default Value: 0x0000_0000                                                 |
| Bit          | Read/Write | Default | Description                                                                                           |
| 31:7         | /          | /       | /                                                                                                     |
| 6:0          |            |         | <p>Receive FIFO Level<br/>         This indicates the number of data entries in the receive FIFO.</p> |

#### 19.4.16. UART Halt TX Register

|              |            |         |                                                                                                                             |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xA4 |            |         | Register Name: UART_HALT<br>Default Value: 0x0000_0000                                                                      |
| Bit          | Read/Write | Default | Description                                                                                                                 |
| 31:6         | /          | /       | /                                                                                                                           |
| 5            | R/W        | 0       | <p>SIR Receiver Pulse Polarity Invert<br/>         0: Not invert receiver signal<br/>         1: Invert receiver signal</p> |
| 4            | R/W        | 0       | <p>SIR Transmit Pulse Polarity Invert<br/>         0: Not invert transmit pulse</p>                                         |

|     |     |   |                                                                                                                                                                                                                                                                                                                                        |
|-----|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 1: Invert transmit pulse                                                                                                                                                                                                                                                                                                               |
| 3:1 | /   | / | /                                                                                                                                                                                                                                                                                                                                      |
| 0   | R/W | 0 | <p>Halt TX</p> <p>This register is use 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>Note: If FIFOs are not enabled, the setting of the halt TX register has no effect on operation.</p> |

## 19.5. UART Special Requirement

### 19.5.1. UART Pin List

| Port Name  | Width | Direction | Description                                                                                                                                 |
|------------|-------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| UART0_TX   | 1     | OUT       | UART Serial Bit output                                                                                                                      |
| UART0_RX   | 1     | IN        | UART Serial Bit input                                                                                                                       |
| UART1_TX   | 1     | OUT       | UART Serial Bit output                                                                                                                      |
| UART1_RX   | 1     | IN        | UART Serial Bit input                                                                                                                       |
| UART1_RTS  |       | OUT       | <p>UART Request To Send</p> <p>This active low output signal informs Modem that the UART is ready to send data</p>                          |
| UART1_CTS  |       | IN        | <p>UART Clear To End</p> <p>This active low signal is an input showing when Modem is ready to accept data</p>                               |
| UART1_DTR  |       | OUT       | <p>UART Data Terminal Ready</p> <p>This active low output signal informs Modem that the UART is ready to establish a communication link</p> |
| UART1_DSR  |       | IN        | <p>UART Data Set Ready</p> <p>This active low signal is an input indicating when Modem is ready to set up a link with the UART0</p>         |
| UART1_DCD  |       | IN        | <p>UART Data Carrier Detect</p> <p>This active low signal is an input indicating when Modem has detected a carrier</p>                      |
| UART1_RING |       | IN        | <p>UART Ring Indicator</p> <p>This active low signal is an input showing when Modem has sensed a ring signal on the telephone line</p>      |
| UART2_TX   | 1     | OUT       | UART Serial Bit output                                                                                                                      |
| UART2_RX   | 1     | IN        | UART Serial Bit input                                                                                                                       |
| UART2_RTS  | 1     | OUT       | <p>UART Request To Send</p> <p>This active low output signal informs Modem that the UART is ready to send data</p>                          |

|           |   |     |                                                                                                         |
|-----------|---|-----|---------------------------------------------------------------------------------------------------------|
| UART2_CTS | 1 | IN  | UART Clear To End<br>This active low signal is an input showing when Modem is ready to accept data      |
| UART3_TX  | 1 | OUT | UART Serial Bit output                                                                                  |
| UART3_RX  | 1 | IN  | UART Serial Bit input                                                                                   |
| UART3_RTS | 1 | OUT | UART Request To Send<br>This active low output signal informs Modem that the UART is ready to send data |
| UART3_CTS | 1 | IN  | UART Clear To End<br>This active low signal is an input showing when Modem is ready to accept data      |

### 19.5.2. IrDA Inverted Signals

When the UART is working in IrDA mode (MCR[6]='1'), if HALT[4] is set to '1', the signal is inverted before transferring to pin SOUT, and if HALT[5] is set to '1', the signal is inverted after receiving from pin SIN.

## 20. CIR Interface

### 20.1. Overview

The CIR features:

- Full physical layer implementation
- Support CIR for remote control or wireless keyboard
- 8x64-bit FIFO for data transfer
- Programmable FIFO thresholds
- Support Interrupt and DMA

CIR receiver is implemented in hardware to save CPU resource. It samples the input signals on the programmable frequency and records these samples into RX FIFO when one CIR signal is found on the air. The CIR receiver uses Run-Length Code (RLC) to encode pulse width, and the encoded data is buffered in a 64 levels and 8-bit width RX FIFO: the MSB bit is used to record the polarity of the receiving CIR signal (The high level is represented as 1 and the low level is represented as 0), and the rest 7 bits are used for the length of RLC. The maximum length is 128. If the duration of one level (high or low) is more than 128, another byte is used. Since there are always some noises in the air, a threshold can be set to filter the noises to reduce system loading and improve system stability.

### 20.2. CIR Register List

| Module Name | Base Address |
|-------------|--------------|
| CIR         | 0x01C21800   |

| Register Name | Offset | Description                             |
|---------------|--------|-----------------------------------------|
| CIR_CTL       | 0x00   | CIR Control Register                    |
| CIR_RXCTL     | 0x10   | CIR Receiver Configure Register         |
| CIR_RXFIFO    | 0x20   | CIR Receiver FIFO Register              |
| CIR_RXINT     | 0x2C   | CIR Receiver Interrupt Control Register |
| CIR_RXSTA     | 0x30   | CIR Receiver Status Register            |
| CIR_CONFIG    | 0x34   | CIR Configure Register                  |

### 20.3. CIR Register Description

#### 20.3.1. CIR Control Register

|              |            |         |                                                                                                      |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: CIR_CTL<br>Default Value: 0x0000_0000                                                 |
| Bit          | Read/Write | Default | Description                                                                                          |
| 31:9         | /          | /       | /                                                                                                    |
| 8            | R/W        | 0       | CGPO<br>General Program Output (GPO) Control in CIR mode for TX Pin<br>0: Low level<br>1: High level |

|     |     |   |                                                                                                                                              |
|-----|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6 | /   | / | /                                                                                                                                            |
| 5:4 | R/W | 0 | CIR ENABLE<br>00~10: /<br>11: CIR mode enable                                                                                                |
| 3:2 | /   | / | /                                                                                                                                            |
| 1   | R/W | 0 | RXEN<br>Receiver Block Enable<br>0: Disable<br>1: Enable                                                                                     |
| 0   | R/W | 0 | 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 |

### 20.3.2. CIR Receiver Configure Register

|              |            |         |                                                                                                      |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------|
| Offset: 0x10 |            |         | Register Name: IR_RXCTL<br>Default Value: 0x0000_0000                                                |
| Bit          | Read/Write | Default | Description                                                                                          |
| 31:3         | /          | /       | /                                                                                                    |
| 2            | R/W        | 1       | RPPI<br>Receiver Pulse Polarity Invert<br>0: Not invert receiver signal<br>1: Invert receiver signal |
| 1:0          | /          | /       | /                                                                                                    |

### 20.3.3. CIR Receiver FIFO Register

|              |            |         |                                                        |
|--------------|------------|---------|--------------------------------------------------------|
| Offset: 0x20 |            |         | Register Name: IR_RXFIFO<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                            |
| 31:8         | /          | /       | /                                                      |
| 7:0          | R          | 0       | Receiver Byte FIFO                                     |

### 20.3.4. CIR Receiver Interrupt Control Register

|              |            |         |                                                                            |
|--------------|------------|---------|----------------------------------------------------------------------------|
| Offset: 0x2C |            |         | Register Name: IR_RXINT<br>Default Value: 0x0000_0000                      |
| Bit          | Read/Write | Default | Description                                                                |
| 31:12        | /          | /       | /                                                                          |
| 11:6         | R/W        | 0       | RAL<br>RX FIFO Available Received Byte Level for interrupt and DMA request |

|     |     |   |                                                                                                                                                                                                           |
|-----|-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | TRIGGER_LEVEL = RAL + 1                                                                                                                                                                                   |
| 5   | R/W | 0 | <p>DRQ_EN<br/>RX FIFO DMA Enable<br/>0: Disable<br/>1: Enable</p> <p>When set to '1', the Receiver FIFO DRQ is asserted if reaching RAL. The DRQ is de-asserted when condition fails.</p>                 |
| 4   | R/W | 0 | <p>RAI_EN<br/>RX FIFO Available Interrupt Enable<br/>0: Disable<br/>1: Enable</p> <p>When set to '1', the Receiver FIFO IRQ is asserted if reaching RAL. The IRQ is de-asserted when condition fails.</p> |
| 3:2 | /   | / | /                                                                                                                                                                                                         |
| 1   | R/W | 0 | <p>RPEI_EN<br/>Receiver Packet End Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                      |
| 0   | R/W | 0 | <p>ROI_EN<br/>Receiver FIFO Overrun Interrupt Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                     |

### 20.3.5. CIR Receiver Status Register

| Offset: 0x30 |            |         | Register Name: IR_RXSTA<br>Default Value: 0x0000_0000                                                                                                                                                          |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                    |
| 31:13        | /          | /       | /                                                                                                                                                                                                              |
| 12:6         | R          | 0       | <p>RAC<br/>RX FIFO Available Counter<br/>0: No available data in RX FIFO<br/>1: 1 byte available data in RX FIFO<br/>2: 2 byte available data in RX FIFO<br/>...<br/>64: 64 byte available data in RX FIFO</p> |
| 5            | /          | /       | /                                                                                                                                                                                                              |
| 4            | R/W        | 0       | <p>RA<br/>RX FIFO Available<br/>0: RX FIFO not available according its level<br/>1: RX FIFO available according its level<br/>This bit is cleared by writing a '1'.</p>                                        |
| 3:2          | /          | /       | /                                                                                                                                                                                                              |
| 1            | R/W        | 0       | RPE                                                                                                                                                                                                            |

|   |     |   |                                                                                                                                                                                                                                                                                                                                          |
|---|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |   | <p>Receiver Packet End Flag<br/>         0: STO was not detected. In CIR mode, one CIR symbol is receiving or not detected.<br/>         1: STO field or packet abort symbol (7'b0000,000 and 8'b0000,0000 for MIR and FIR) is detected. In CIR mode, one CIR symbol is received.<br/>         This bit is cleared by writing a '1'.</p> |
| 0 | R/W | 0 | <p>ROI<br/>         Receiver FIFO Overrun<br/>         0: Receiver FIFO not overrun<br/>         1: Receiver FIFO overrun<br/>         This bit is cleared by writing a '1'.</p>                                                                                                                                                         |

### 20.3.6. CIR Configure Register

| Offset: 0x34 |            |         | Register Name: IR_CIR<br><br>Default Value: 0x0000_1828                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:16        | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:8         | R/W        | 0x18    | <p>ITHR<br/>         Idle Threshold for CIR<br/>         The Receiver uses it to decide whether the CIR command has been received. If there is no CIR signal on the air, the receiver is staying in IDLE status. One active pulse will bring the receiver from IDLE status to Receiving status. After the CIR is end, the inputting signal will keep the specified level (high or low level) for a long time. The receiver can use this idle signal duration to decide that it has received the CIR command. The corresponding flag is asserted. If the corresponding interrupt is enabled, the interrupt line is asserted to CPU.<br/>         When the duration of signal keeps one status (high or low level) for the specified duration ( (ITHR + 1)*128 sample_clk ), this means that the previous CIR command has been finished.</p> |
| 7:2          | R/W        | 0xa     | <p>NTHR<br/>         Noise Threshold for CIR<br/>         When the duration of signal pulse (high or low level) is less than NTHR, the pulse is taken as noise and should be discarded by hardware.<br/>         0: all samples are recorded into RX FIFO<br/>         1: If the signal is only one sample duration, it is taken as noise and discarded.<br/>         2: If the signal is less than (<math>\leq</math>) two sample duration, it is taken as noise and discarded.<br/>         ...</p>                                                                                                                                                                                                                                                                                                                                      |

|     |     |   |                                                                                                                                                                               |
|-----|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 61: if the signal is less than ( $\leq$ ) sixty-one sample duration, it is taken as noise and discarded.                                                                      |
| 1:0 | R/W | 0 | SCS<br>Sample Clock Select for CIR<br>0: CIR sample_clk is ir_clk/64<br>1: CIR sample_clk is ir_clk/128<br>2: CIR sample_clk is ir_clk/256<br>3: CIR sample_clk is ir_clk/512 |

## 21. USB DRD Controller

### 21.1. Overview

The USB DRD Controller supports Host and Device functions. It can also be configured as a Host-only or Device-only controller, full compliant with the USB 2.0 Specification. The USB DRD can support high-speed (HS, 480-Mbps), full-speed (FS, 12-Mbps), and low-speed (LS, 1.5-Mbps) transfers in Host mode, support high-speed (HS, 480-Mbps) and full-speed (FS, 12-Mbps) in Device mode.

The USB2.0 DRD controller (SIE) features:

- 64-Byte Endpoint 0 for Control Transfer.
- Support up to 5 User-Configurable Endpoints for Bulk , Isochronous, Control and Interrupt bi-directional transfers.
- Support High-Bandwidth Isochronous & Interrupt transfers
- Support point-to-point and point-to-multipoint transfer in both Host and Peripheral mode

## 22. USB Host Controller

### 22.1. Overview

USB Host Controller is fully compliant with the USB 2.0 specification, Enhanced Host Controller Interface (EHCI) Specification, Revision 1.0, and the Open Host Controller Interface (OHCI) Specification Release 1.0a. The controller supports high-speed, 480-Mbps transfers (40 times faster than USB 1.1 full-speed mode) using an EHCI Host Controller, as well as full and low speeds through one or more integrated OHCI Host Controllers.

The USB host controller features:

- Include an internal DMA Controller for data transfer with memory.
- Comply with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the Open Host Controller Interface (OHCI) Specification, Version 1.0a.
- Support High-Speed (HS, 480-Mbps), Full-Speed (FS, 12-Mbps), and Low-Speed (LS, 1.5-Mbps) Device.
- Support one USB Root Port shared between EHCI and OHCI.

### 22.2. USB Host Block Diagram

The USB host controller System-Level block diagram is showed below:



Figure22-1 USB Host Block Diagram

## 22.3. USB Host Timing Diagram

Please refer USB2.0 Specification, Enhanced Host Controller Interface (EHCI) Specification, Version 1.0, and the Open Host Controller Interface (OHCI) Specification, Version 1.0a.

## 22.4. USB Host Register List

| Module Name | Base Address |
|-------------|--------------|
| USB_HCI0    | 0x01C14000   |

| Register Name                    | Offset | Description                                     |
|----------------------------------|--------|-------------------------------------------------|
| <b>EHCI Capability Register</b>  |        |                                                 |
| E_CAPLENGTH                      | 0x000  | EHCI Capability register Length Register        |
| E_HCIVERSION                     | 0x002  | EHCI Host Interface Version Number Register     |
| E_HCSPARAMS                      | 0x004  | EHCI Host Control Structural Parameter Register |
| E_HCCPARAMS                      | 0x008  | EHCI Host Control Capability Parameter Register |
| E_HCSPPORTROUTE                  | 0x00c  | EHCI Companion Port Route Description           |
| <b>EHCI Operational Register</b> |        |                                                 |
| E_USBCMD                         | 0x010  | EHCI USB Command Register                       |
| E_USBSTS                         | 0x014  | EHCI USB Status Register                        |
| E_USBINTR                        | 0x018  | EHCI USB Interrupt Enable Register              |
| E_FRINDEX                        | 0x01c  | EHCI USB Frame Index Register                   |
| E_CTRLDSEGMENT                   | 0x020  | EHCI 4G Segment Selector Register               |
| E_PERIODICLISTBASE               | 0x024  | EHCI Frame List Base Address Register           |

|                                                   |       |                                              |
|---------------------------------------------------|-------|----------------------------------------------|
| E_ASYNCNCLISTADDR                                 | 0x028 | EHCI Next Asynchronous List Address Register |
| E_CONFIGFLAG                                      | 0x050 | EHCI Configured Flag Register                |
| E_PORTSC                                          | 0x054 | EHCI Port Status/Control Register            |
| <b>OHCI Control and Status Partition Register</b> |       |                                              |
| O_HcRevision                                      | 0x400 | OHCI Revision Register                       |
| O_HcControl                                       | 0x404 | OHCI Control Register                        |
| O_HcCommandStatus                                 | 0x408 | OHCI Command Status Register                 |
| O_HcInterruptStatus                               | 0x40c | OHCI Interrupt Status Register               |
| O_HcInterruptEnable                               | 0x410 | OHCI Interrupt Enable Register               |
| O_HcInterruptDisable                              | 0x414 | OHCI Interrupt Disable Register              |
| <b>OHCI Memory Pointer Partition Register</b>     |       |                                              |
| O_HcHCCA                                          | 0x418 | OHCI HCCA Base                               |
| O_HcPeriodCurrentED                               | 0x41c | OHCI Period Current ED Base                  |
| O_HcControlHeadED                                 | 0x420 | OHCI Control Head ED Base                    |
| O_HcControlCurrentED                              | 0x424 | OHCI Control Current ED Base                 |
| O_HcBulkHeadED                                    | 0x428 | OHCI Bulk Head ED Base                       |
| O_HcBulkCurrentED                                 | 0x42c | OHCI Bulk Current ED Base                    |
| O_HcDoneHead                                      | 0x430 | OHCI Done Head Base                          |
| <b>OHCI Frame Counter Partition Register</b>      |       |                                              |
| O_HcFmInterval                                    | 0x434 | OHCI Frame Interval Register                 |
| O_HcFmRemaining                                   | 0x438 | OHCI Frame Remaining Register                |
| O_HcFmNumber                                      | 0x43c | OHCI Frame Number Register                   |
| O_HcPeriodicStart                                 | 0x440 | OHCI Periodic Start Register                 |
| O_HcLSThreshold                                   | 0x444 | OHCI LS Threshold Register                   |
| <b>OHCI Root Hub Partition Register</b>           |       |                                              |
| O_HcRhDescriptorA                                 | 0x448 | OHCI Root Hub Descriptor Register A          |
| O_HcRhDescriptorB                                 | 0x44c | OHCI Root Hub Descriptor Register B          |
| O_HcRhStatus                                      | 0x450 | OHCI Root Hub Status Register                |
| O_HcRhPortStatus                                  | 0x454 | OHCI Root Hub Port Status Register           |

## 22.5. EHCI Register Description

### 22.5.1. EHCI Identification Register

|             |            |         |                                                                                                                                           |
|-------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Offset:0x00 |            |         | Register Name: CAPLENGTH<br>Default Value: Implementation Dependent                                                                       |
| Bit         | Read/Write | Default | 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. |

### 22.5.2. EHCI Host Interface Version Number Register

|              |                           |
|--------------|---------------------------|
| Offset: 0x02 | Register Name: HCIVERSION |
|--------------|---------------------------|

|      |            |         | Default Value:0x0100                                                                                                                                                                                                                                                  |
|------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit  | Read/Write | Default | Description                                                                                                                                                                                                                                                           |
| 15:0 | R          | 0x0100  | <b>HCIVERSION</b><br>This is a 16-bits 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. |

### 22.5.3. EHCI Host Control Structural Parameter Register

| Offset: 0x04 |                                                                                                                                                                                         |         | Register Name: HCSPARAMS<br><br>Default Value: Implementation Dependent                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write                                                                                                                                                                              | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |   |                                                                                                                                                                                         |
| 31:24        | /                                                                                                                                                                                       | 0       | Reserved.<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |
| 23:20        | R                                                                                                                                                                                       | 0       | <b>Debug Port Number</b><br>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.<br>This field will always be '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |         |   |                                                                                                                                                                                         |
| 19:16        | /                                                                                                                                                                                       | 0       | Reserved.<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |
| 15:12        | R                                                                                                                                                                                       | 0       | <b>Number of Companion Controller (N_CC)</b><br>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).<br>This field will always be '0'.                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                                                                                                         |
| 11:8         | R                                                                                                                                                                                       | 0       | <b>Number of Port per Companion Controller(N_PCC)</b><br>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.<br>This field will always fix with '0'.                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                                                                                                                                                                         |
| 7            | R                                                                                                                                                                                       | 0       | <b>Port Routing Rules</b><br>This field indicates the method used by this implementation for how all ports are mapped to companion controllers. The value of this field has the following interpretation:<br><table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th style="text-align: center;">Value</th> <th style="text-align: center;">Meaning</th> </tr> </thead> <tbody> <tr> <td style="text-align: center;">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> </tbody> </table> | 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. |
| Value        | Meaning                                                                                                                                                                                 |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |
| 0            | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |

|     |   |   |                                                                                                                                                                                                                                                                                                             |                                                                                                                                            |
|-----|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
|     |   |   | 1                                                                                                                                                                                                                                                                                                           | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.<br><br>This field will always be '0'. |
| 6:4 | / | 0 | Reserved.<br><br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                         |                                                                                                                                            |
| 3:0 | R | 1 | N_PORTS<br><br>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.<br><br>This field is always 1. |                                                                                                                                            |

#### 22.5.4. EHCI Host Control Capability Parameter Register

| Offset: 0x08 |            |         | Register Name: HCCPARAMS<br><br>Default Value: Implementation Dependent                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:16        | /          | 0       | Reserved<br><br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15:18        | R          | 0       | EHCI Extended Capabilities Pointer (EECP)<br><br>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.<br><br>The value of this field is always '00b'.                                               |
| 7:4          | R          |         | Isochronous Scheduling Threshold<br><br>This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.<br><br>When bit[7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures(one or more) before flushing the state. When bit[7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame. |
| 3            | R          | 0       | Reserved<br><br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2            | R          |         | Asynchronous Schedule Park Capability<br><br>If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous                                                                                                                                                                                                                                                                                                                                                                        |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---|---|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.                                                                                                                                                                                                                                                                                                                                                                                   |
| 1 | R |   | <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</p> <p>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</p> <p>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 | R | 0 | <p>Reserved</p> <p>These bits are reserved for future use and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 22.5.5. EHCI Companion Port Route Description

| Offset: 0x0C |            |         | Register Name: HCSP-PORTROUTE<br>Default Value: UNDEFINED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:0         | R          |         | <p><b>HCSP-PORTROUTE</b></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 of 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> |

### 22.5.6. EHCI USB Command Register

| Offset: 0x10 |                                         |         | Register Name: USBCMD<br>Default Value: 0x00080000(0x00080B00 if Asynchronous Schedule Park Capability is a one)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
|--------------|-----------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------|------|----------|------|---------------|------|---------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| Bit          | Read/Write                              | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 31:24        | /                                       | 0       | Reserved<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 23:16        | R/W                                     | 0x08    | <p>Interrupt Threshold Control<br/>The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <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> <p>Any other value in this register yields undefined results.<br/>The default value in this field is 0x08 .<br/>Software modifications to this bit while HC Halted bit equals to zero results in undefined behavior.</p> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame | 0x04 | 4 micro-frame | 0x08 | 8 micro-frame(default, equates to 1 ms) | 0x10 | 16 micro-frame(2ms) | 0x20 | 32 micro-frame(4ms) | 0x40 | 64 micro-frame(8ms) |
| Value        | Minimum Interrupt Interval              |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x00         | Reserved                                |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x01         | 1 micro-frame                           |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x02         | 2 micro-frame                           |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x04         | 4 micro-frame                           |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x08         | 8 micro-frame(default, equates to 1 ms) |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x10         | 16 micro-frame(2ms)                     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x20         | 32 micro-frame(4ms)                     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x40         | 64 micro-frame(8ms)                     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 15:12        | /                                       | 0       | Reserved<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 11           | R/W or R                                | 0       | Asynchronous Schedule Park Mode Enable(OPTIONAL)<br>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 10           | /                                       | 0       | Reserved<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 9:8          | R/W or R                                | 0       | Asynchronous Schedule Park Mode Count(OPTIONAL)<br>Asynchronous Park Capability bit in the HCCPARAMS register is a one,<br>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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |

|           |                                                                    |   | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           |         |   |                                           |   |                                                                    |
|-----------|--------------------------------------------------------------------|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|---|-------------------------------------------|---|--------------------------------------------------------------------|
| 7         | R/W                                                                | 0 | <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                                                                | 0 | <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 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                                                                | 0 | <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                                                                | 0 | <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> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Bit Value | Meaning |   |                                           |   |                                                                    |
| Bit Value | Meaning                                                            |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |         |   |                                           |   |                                                                    |

|      |                                                                    |   | <table border="1"> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0    | Do not process the Periodic Schedule. | 1   | Use the PERIODICLISTBASE register to access the Periodic Schedule. |     |                         |     |                                                           |     |          |
|------|--------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------------------------------------|-----|--------------------------------------------------------------------|-----|-------------------------|-----|-----------------------------------------------------------|-----|----------|
| 0    | Do not process the Periodic Schedule.                              |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                       |     |                                                                    |     |                         |     |                                                           |     |          |
| 1    | Use the PERIODICLISTBASE register to access the Periodic Schedule. |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                       |     |                                                                    |     |                         |     |                                                           |     |          |
| 3:2  | R/W or R                                                           | 0 | <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                                                           |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                       |     |                                                                    |     |                         |     |                                                           |     |          |
| 1    | R/W                                                                | 0 | <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                                                                | 0 | <p>Run/Stop</p> <p>When set to a 1, the Host Controller proceeds with execution of the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |                                       |     |                                                                    |     |                         |     |                                                           |     |          |

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

### 22.5.7. EHCI USB Status Register

| Offset: 0x14 |            |         | Register Name: USBSTS<br>Default Value: 0x00001000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:16        | /          | 0       | Reserved<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15           | R          | 0       | Asynchronous Schedule Status<br>The bit reports the current real status of Asynchronous Schedule. If this bit is a zero then the status of the Asynchronous Schedule is disabled. If this bit is a one then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0). |
| 14           | R          | 0       | 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 immediately disable or enable the Periodic Schedule when software transitions the Periodic Schedule Enable bit in the USBCMD register. When this bit and the Periodic Schedule Enable bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0).                             |
| 13           | R          | 0       | Reclamation<br>This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12           | R          | 1       | 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 | /    | 0 | Reserved<br>These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5    | R/WC | 0 | 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 | 0 | 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 | 0 | Frame List Rollover<br>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX [12] toggles.                                                            |
| 2    | R/WC | 0 | 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 | 0 | 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 | 0 | 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.                                                                                                                                                                                                                                                                                                              |

|  |  |  |                                                                                                                                                             |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | The Host Controller also sets this bit to 1 when a short packet is detected<br>(actual number of bytes received was less than the expected number of bytes) |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 22.5.8. EHCI USB Interrupt Enable Register

| Offset: 0x18 |            |         | Register Name: USBINTR<br>Default Value: 0x00000000                                                                                                                                                                                                                                              |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                      |
| 31:6         | /          | 0       | Reserved<br>These bits are reserved and should be zero.                                                                                                                                                                                                                                          |
| 5            | R/W        | 0       | 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. |
| 4            | R/W        | 0       | 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        | 0       | 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        | 0       | 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        | 0       | 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        | 0       | 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                                                    |

### 22.5.9. EHCI Frame Index Register

|              |                        |
|--------------|------------------------|
| Offset: 0x1c | Register Name: FRINDEX |
|--------------|------------------------|

|                         |                 |         | Default Value: 0x00000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
|-------------------------|-----------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|---|-----|------|----|-----|-----|----|-----|-----|----|-----|----------|--|
| Bit                     | Read/Write      | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 31:14                   | /               | 0       | <p>Reserved</p> <p>These bits are reserved and should be zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
|                         |                 |         | <p>Frame Index</p> <p>The value in this register increment at the end of each time frame (e.g. micro-frame). Bits[N:3] are used for the Frame List current index. It</p> <p>Means that each location of the frame list is accessed 8 times(frames or Micro-frames) before moving to the next index. The following illustrates</p> <p>Values of N based on the value of the Frame List Size field in the USBCMD register.</p> <table border="1"> <thead> <tr> <th>USBCMD[Frame List Size]</th><th>Number Elements</th><th>N</th></tr> </thead> <tbody> <tr> <td>00b</td><td>1024</td><td>12</td></tr> <tr> <td>01b</td><td>512</td><td>11</td></tr> <tr> <td>10b</td><td>256</td><td>10</td></tr> <tr> <td>11b</td><td>Reserved</td><td></td></tr> </tbody> </table> | USBCMD[Frame List Size] | Number Elements | N | 00b | 1024 | 12 | 01b | 512 | 11 | 10b | 256 | 10 | 11b | Reserved |  |
| USBCMD[Frame List Size] | Number Elements | N       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 00b                     | 1024            | 12      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 01b                     | 512             | 11      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 10b                     | 256             | 10      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 11b                     | Reserved        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 13:0                    | R/W             | 0       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |

Note: This register must be written as a DWord. Byte writes produce undefined results.

#### 22.5.10. EHCI Periodic Frame List Base Address Register

| Offset: 0x24 |            |         | Register Name: PERIODICLISTBASE<br>Default Value: Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:12        | R/W        |         | <p>Base Address</p> <p>These bits correspond to memory address signals [31:12], respectively.</p> <p>This register contains the beginning address of the Periodic Frame List in the system memory.</p> <p>System software loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4-K byte aligned.</p> <p>The contents of this register are combined with the Frame Index Register (FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence.</p> |
| 11:0         | /          |         | <p>Reserved</p> <p>Must be written as 0x0 during runtime, the values of these bits are undefined.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Note: Writes must be Dword Writes.

### 22.5.11.EHCI Current Asynchronous List Address Register

| Offset: 0x28 |            |         | Register Name: ASYNCLISTADDR<br>Default Value: Undefined                                                                                                                                            |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                         |
| 31:5         | R/W        |         | <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          | /          | /       | <p>Reserved</p> <p>These bits are reserved and their value has no effect on operation.</p> <p>Bits in this field cannot be modified by system software and will always return a zero when read.</p> |

Note: Write must be DWord Writes.

### 22.5.12.EHCI Configure Flag Register

| Offset: 0x50 |                                                                                                            |         | Register Name: CONFIGFLAG<br>Default Value: 0x00000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                                            |   |                                                                             |
|--------------|------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit          | Read/Write                                                                                                 | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                            |   |                                                                             |
| 31:1         | /                                                                                                          | 0       | <p>Reserved</p> <p>These bits are reserved and should be set to zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |         |   |                                                                                                            |   |                                                                             |
| 0            | R/W                                                                                                        | 0       | <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 use in the normal implementation.

### 22.5.13.EHCI Port Status and Control Register

| Offset: 0x54 |            |         | Register Name: PORTSC<br>Default Value: 0x00002000(w/PPC set to one);0x00003000(w/PPC set to a zero)       |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                |
| 31:22        | /          | 0       | <p>Reserved</p> <p>These bits are reserved for future use and should return a value of zero when read.</p> |
| 21           | R/W        | 0       | Wake on Disconnect Enable(WKDSNNT_E)                                                                       |

|             |                                           |   | Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br>This field is zero if Port Power is zero.<br>The default value in this field is '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
|-------------|-------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|-------|-------------------------------------------|-------|--------------|-------|--------------|-------|--------------|-------|-------------|-------|-------------------|-------------|----------|
| 20          | R/W                                       | 0 | 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'.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 19:16       | R/W                                       | 0 | <p>Port Test Control</p> <p>The value in this field specifies the test mode of the port. The encoding of the test mode bits are as follow:</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 SE0_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 SE0_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 SE0_NAK                              |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0100b       | Test Packet                               |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0101b       | Test FORCE_ENABLE                         |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0110b-1111b | Reserved                                  |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 15:14       | R/W                                       | 0 | <p>Reserved</p> <p>These bits are reserved for future use and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 13          | R/W                                       | 1 | <p>Port Owner</p> <p>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.</p> <p>System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.</p> <p>Default Value = 1b.</p>                                                                         |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 12          | /                                         | 0 | <p>Reserved</p> <p>These bits are reserved for future use and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 11:10       | R                                         | 0 | <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.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |

|                   |                  |                                              | <p>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><b>Bit[11:10]</b></th><th><b>USB State</b></th><th><b>Interpretation</b></th></tr> </thead> <tbody> <tr> <td>00b</td><td>SE0</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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | <b>Bit[11:10]</b> | <b>USB State</b> | <b>Interpretation</b> | 00b | SE0 | 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. |
|-------------------|------------------|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------|-----------------------|-----|-----|-------------------------------------------|-----|---------|-------------------------------------------|-----|---------|----------------------------------------------|-----|-----------|-------------------------------------------|
| <b>Bit[11:10]</b> | <b>USB State</b> | <b>Interpretation</b>                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                  |                       |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 00b               | SE0              | 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                 | /                | 0                                            | <p>Reserved</p> <p>This bit is reserved for future use, and should return a value of zero when read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                   |                  |                       |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 8                 | R/W              | 0                                            | <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. Notes: when software writes this bit to a one , it must also write a zero to the Port Enable bit.</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> <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              | 0                                            | <p>Suspend</p> <p>Port Enabled Bit and Suspend bit of this register define the port states as follows:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                  |                       |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |

|   |     |   | <b>Bits[Port Enables,<br/>Suspend]</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>Port State</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |   | 0x                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   |     |   | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|   |     |   | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Suspend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|   |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 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.               |
|   |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:<br>① Software sets the Force Port Resume bit to a zero(from a one).<br>② Software sets the Port Reset bit to a one(from a zero).<br>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.<br>This field is zero if Port Power is zero.<br>The default value in this field is '0'. |
| 6 | R/W | 0 | Force Port Resume<br>1 = Resume detected/driven on port. 0 = No resume (K-state) detected/ driven on port. Default value = 0.<br><br>This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined.<br><br>Software sets this bit to a 1 drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit to a one, the host controller must not set the Port Change Detect bit.<br><br>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|   |      |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---|------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |      |   | <p>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 | 0 | <p>Over-current Change</p> <p>Default = 0. This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4 | R    | 0 | <p>Over-current Active</p> <p>0 = This port does not have an over-current condition. 1 = This port currently has an over-current condition. This bit will automatically transition from a one to a zero when the over current condition is removed.</p> <p>The default value of this bit is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3 | R/WC | 0 | <p>Port Enable/Disable Change</p> <p>Default = 0. 1 = Port enabled/disabled status has changed. 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  | 0 | <p>Port Enabled/Disabled</p> <p>1=Enable, 0=Disable. Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.</p> <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 | 0 | <p>Connect Status Change</p> <p>1=Change in Current Connect Status, 0=No change, Default=0.</p> <p>Indicates a change has occurred in the port's Current Connect Status. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

|   |   |   |                                                                                                                                                                                                                                                                                                                                                                       |
|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | 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.<br>This field is zero if Port Power is zero.                                                                                                                                             |
| 0 | R | 0 | Current Connect Status<br>Device is present on port when the value of this field is a one, and no device is present on port when the value of this field is a zero. This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change(Bit 1) to be set.<br>This field is zero if Port Power zero. |

Note: This register is only reset by hardware or in response to a host controller reset.

## 22.6. OHCI Register Description

### 22.6.1. HcRevision Register

| Offset: 0x400 |            |    |         | Register Name: HcRevision<br>Default Value:0x10                                                                                                                                                                                                                                                       |
|---------------|------------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                           |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                                       |
| 31:8          | /          | /  | 0x00    | Reserved                                                                                                                                                                                                                                                                                              |
| 7:0           | R          | R  | 0x10    | Revision<br>This read-only field contains the BCD representation of the version of the HCI specification that is implemented by this HC. For example, a value of 0x11 corresponds to version 1.1. All of the HC implementations that are compliant with this specification will have a value of 0x10. |

### 22.6.2. HcControl Register

| Offset: 0x404 |            |     |         | Register Name: HcRevision<br>Default Value:0x0                                                                                                                                                                                                                                                                                                     |
|---------------|------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                        |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                    |
| 31:11         | /          | /   | 0x00    | Reserved                                                                                                                                                                                                                                                                                                                                           |
| 10            | R/W        | R   | 0x0     | RemoteWakeUpEnable<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 ResumeDetected bit in HcInterruptStatus is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt. |
| 9             | R/W        | R/W | 0x0     | RemoteWakeUpConnected<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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |          |     |           |     |                |     |            |
| 8   | R/W            | R   | 0x0 | <p><b>InterruptRouting</b></p> <p>This bit determines the routing of interrupts generated by events registered in HcInterruptStatus. 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" style="margin-left: auto; margin-right: auto;"> <tr><td>00b</td><td>USBReset</td></tr> <tr><td>01b</td><td>USBResume</td></tr> <tr><td>10b</td><td>USBOperational</td></tr> <tr><td>11b</td><td>USBSuspend</td></tr> </table> <p>A transition to USBOperational from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the StartOfFrame field of HcInterruptStatus.</p> <p>This field may be changed by HC only when in the USBSUSPEND state. HC may move from the USBSUSPEND state to the USBRESUME state after detecting the resume signaling from a downstream port.</p> <p>HC enters USBSUSPEND after a software reset, whereas it enters USBRESET after a hardware reset. The latter also resets the Root Hub and asserts subsequent reset signaling to downstream ports.</p> | 00b | USBReset | 01b | USBResume | 10b | USBOperational | 11b | USBSuspend |
| 00b | USBReset       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 01b | USBResume      |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 10b | USBOperational |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 11b | USBSuspend     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 5   | R/W            | R   | 0x0 | <p><b>BulkListEnable</b></p> <p>This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by HCD, processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If HcBulkCurrentED is pointing to an ED to be removed, HCD must advance the pointer by updating HcBulkCurrentED 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, 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 HcControlCurrentED is pointing to an ED to be removed, HCD must advance the pointer by updating HcControlCurrentED before re-enabling processing of the list.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |

|      |                                         |   |     | IsochronousEnable<br>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists.<br>Setting this bit is guaranteed to take effect in the next Frame (not the current Frame). |      |                                         |   |     |   |     |   |     |   |     |
|------|-----------------------------------------|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|---|-----|---|-----|---|-----|
| 3    | R/W                                     | R | 0x0 | PeriodicListEnable<br>This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.                                                                                                                                                                                                                                                                       |      |                                         |   |     |   |     |   |     |   |     |
| 2    | R/W                                     | R | 0x0 | ControlBulkServiceRatio<br>This specifies the service ratio between Control and Bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value.                                    |      |                                         |   |     |   |     |   |     |   |     |
| 1:0  | R/W                                     | R | 0x0 | The default value is 0x0.<br><table border="1" data-bbox="682 1156 1453 1381"> <thead> <tr> <th>CBSR</th><th>No. of Control EDs Over Bulk EDs Served</th></tr> </thead> <tbody> <tr> <td>0</td><td>1:1</td></tr> <tr> <td>1</td><td>2:1</td></tr> <tr> <td>2</td><td>3:1</td></tr> <tr> <td>3</td><td>4:1</td></tr> </tbody> </table>                                                                                                                                                                                       | CBSR | No. of Control EDs Over Bulk EDs Served | 0 | 1:1 | 1 | 2:1 | 2 | 3:1 | 3 | 4:1 |
| CBSR | No. of Control EDs Over Bulk EDs Served |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 0    | 1:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 1    | 2:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 2    | 3:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 3    | 4:1                                     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |

### 22.6.3. HcCommandStatus Register

|               |            |     |                                                     |                                                                                                                                                                                                                                                                                                                                                |  |
|---------------|------------|-----|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Offset: 0x408 |            |     | Register Name: HcCommandStatus<br>Default Value:0x0 |                                                                                                                                                                                                                                                                                                                                                |  |
| Bit           | Read/Write |     | Default                                             | Description                                                                                                                                                                                                                                                                                                                                    |  |
|               | HCD        | HC  |                                                     |                                                                                                                                                                                                                                                                                                                                                |  |
| 31:18         | /          | /   | 0x0                                                 | Reserved                                                                                                                                                                                                                                                                                                                                       |  |
| 17:16         | R          | R/W | 0x0                                                 | SchedulingOverrunCount<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 SchedulingOverrun in HcInterruptStatus has already been set. This is used by HCD to monitor any persistent scheduling problem. |  |

|      |     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:4 | /   | /   | 0x0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3    | R/W | R/W | 0x0 | <p><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 OwnershipChange field in HcInterruptStatus. After the changeover, this bit is cleared and remains so until the next request from OS HCD.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2    | R/W | R/W | 0x0 | <p><b>BulkListFilled</b><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 BulkListFilled is 0, HC will not start processing the Bulk list. If BulkListFilled 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 BulkListFilled to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set BulkListFilled, then BulkListFilled will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop.</p>                                                       |
| 1    | R/W | R/W | 0x0 | <p><b>ControlListFilled</b><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 CLF. As long as ControlListFilled is 0, HC will not start processing the Control list. If CF is 1, HC will start processing the Control list and will set ControlListFilled to 0. If HC finds a TD on the list, then HC will set ControlListFilled 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 ControlListFilled, then ControlListFilled will still be 0 when HC completes processing the Control list and Control list processing will stop.</p> |
| 0    | R/W | R/E | 0x0 | <p><b>HostControllerReset</b><br/> 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>                                                                                                                                                                   |

#### **22.6.4. HcInterruptStatus Register**

| Offset: 0x40c |            |     |             | Register Name: HcInterruptStatus<br>Default Value: 0x00                                                                                                                                                                                                              |
|---------------|------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default     | Description                                                                                                                                                                                                                                                          |
|               | HCD        | HC  |             |                                                                                                                                                                                                                                                                      |
| 31:7          | /          | /   | 0x0         | Reserved                                                                                                                                                                                                                                                             |
| 6             | R/W        | R/W | 0x0<br>0x1? | RootHubStatusChange<br>This bit is set when the content of HcRhStatus or the content of any of HcRhPortStatus[NumberofDownstreamPort] has changed.                                                                                                                   |
| 5             | R/W        | R/W | 0x0         | FrameNumberOverflow<br>This bit is set when the MSb of HcFmNumber (bit 15) changes value, from 0 to 1 or from 1 to 0, and after HccaFrameNumber has been updated.                                                                                                    |
| 4             | R/W        | R/W | 0x0         | UnrecoverableError<br>This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.                            |
| 3             | R/W        | R/W | 0x0         | ResumeDetected<br>This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the USBRseume state.       |
| 2             | R/W        | R/W | 0x0         | StartofFrame<br>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.                                                                                                                |
| 1             | R/W        | R/W | 0x0         | WritebackDoneHead<br>This bit is set immediately after HC has written HcDoneHead to HccaDoneHead. Further updates of the HccaDoneHead will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of HccaDoneHead. |
| 0             | R/W        | R/W | 0x0         | SchedulingOverrun<br>This bit is set when the USB schedule for the current Frame overruns and after the update of HccaFrameNumber. A scheduling overrun will also cause the SchedulingOverrunCount of HcCommandStatus to be Incremented.                             |

#### **22.6.5. HcInterruptEnable Register**

| Offset: 0x410 |            |         | Register Name: HcInterruptEnable Register<br>Default Value: 0x0 |
|---------------|------------|---------|-----------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                     |

|      | HCD                                                        | HC |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
|------|------------------------------------------------------------|----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|------------------------------------------------------------|
| 31   | R/W                                                        | R  | 0x0 | <p>MasterInterruptEnable</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 | /                                                          | /  | 0x0 | Reserved                                                                                                                                                                                                                                               |   |         |   |                                                            |
| 6    | R/W                                                        | R  | 0x0 | <p>RootHubStatusChange Interrupt Enable</p> <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>FrameNumberOverflow Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Frame Number Overflow;</td></tr> </table>                                                    | 0 | Ignore; | 1 | Enable interrupt generation due to Frame Number Overflow;  |
| 0    | Ignore;                                                    |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | Enable interrupt generation due to Frame Number Overflow;  |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 4    | R/W                                                        | R  | 0x0 | <p>UnrecoverableError Interrupt Enable</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 | <p>ResumeDetected Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Resume Detected;</td></tr> </table>                                                               | 0 | Ignore; | 1 | Enable interrupt generation due to Resume Detected;        |
| 0    | Ignore;                                                    |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | Enable interrupt generation due to Resume Detected;        |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 2    | R/W                                                        | R  | 0x0 | <p>StartofFrame Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Start of Flame;</td></tr> </table>                                                                  | 0 | Ignore; | 1 | Enable interrupt generation due to Start of Flame;         |
| 0    | Ignore;                                                    |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | Enable interrupt generation due to Start of Flame;         |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | R/W                                                        | R  | 0x0 | <p>WritebackDoneHead Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Write back Done Head;</td></tr> </table>                                                       | 0 | Ignore; | 1 | Enable interrupt generation due to Write back Done Head;   |
| 0    | Ignore;                                                    |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | Enable interrupt generation due to Write back Done Head;   |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 0    | R/W                                                        | R  | 0x0 | <p>SchedulingOverrun Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Scheduling Overrun;</td></tr> </table>                                                         | 0 | Ignore; | 1 | Enable interrupt generation due to Scheduling Overrun;     |
| 0    | Ignore;                                                    |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |
| 1    | Enable interrupt generation due to Scheduling Overrun;     |    |     |                                                                                                                                                                                                                                                        |   |         |   |                                                            |

### 22.6.6. HcInterruptDisable Register

| Offset: 0x414 |            |    |         | Register Name: HcInterruptDisable Register                                                                                                                                                                                                                 |
|---------------|------------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                            |
| 31            | R/W        | R  | 0x0     | <p>MasterInterruptEnable</p> <p>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.</p> |

|      |                                                             |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
|------|-------------------------------------------------------------|---|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|-------------------------------------------------------------|
| 30:7 | /                                                           | / | 0x00 | Reserved                                                                                                                                                                                               |   |         |   |                                                             |
| 6    | R/W                                                         | R | 0x0  | <p>RootHubStatusChange Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Root Hub Status Change;</td></tr> </table> | 0 | Ignore; | 1 | Disable interrupt generation due to Root Hub Status Change; |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Root Hub Status Change; |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 5    | R/W                                                         | R | 0x0  | <p>FrameNumberOverflow Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Frame Number Over Flow;</td></tr> </table> | 0 | Ignore; | 1 | Disable interrupt generation due to Frame Number Over Flow; |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Frame Number Over Flow; |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 4    | R/W                                                         | R | 0x0  | <p>UnrecoverableError Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Unrecoverable Error;</td></tr> </table>     | 0 | Ignore; | 1 | Disable interrupt generation due to Unrecoverable Error;    |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Unrecoverable Error;    |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 3    | R/W                                                         | R | 0x0  | <p>ResumeDetected Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Resume Detected;</td></tr> </table>             | 0 | Ignore; | 1 | Disable interrupt generation due to Resume Detected;        |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Resume Detected;        |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 2    | R/W                                                         | R | 0x0  | <p>StartofFrame Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Start of Flame;</td></tr> </table>                | 0 | Ignore; | 1 | Disable interrupt generation due to Start of Flame;         |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Start of Flame;         |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | R/W                                                         | R | 0x0  | <p>WritebackDoneHead Interrupt Disable</p> <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    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Write back Done Head;   |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 0    | R/w                                                         | R | 0x0  | <p>SchedulingOverrun Interrupt Disable</p> <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;     |
| 0    | Ignore;                                                     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |
| 1    | Disable interrupt generation due to Scheduling Overrun;     |   |      |                                                                                                                                                                                                        |   |         |   |                                                             |

### 22.6.7. HcHCCA Register

| Offset: 0x418 |            |    | Register Name: HcHCCA<br>Default Value:0x0 |                                                                                                                                                                                                                                                     |
|---------------|------------|----|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default                                    | Description                                                                                                                                                                                                                                         |
|               | HCD        | HC |                                            |                                                                                                                                                                                                                                                     |
| 31:8          | R/W        | R  | 0x0                                        | <p>HCCA[31:8]</p> <p>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.</p> |
| 7:0           | R          | R  | 0x0                                        | <p>HCCA[7:0]</p> <p>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.</p>         |

### 22.6.8. HcPeriodCurrentED Register

| Offset: 0x41c |            |     |         | Register Name: HcPeriodCurrentED(PCED)<br>Default Value: 0x0                                                                                                                                                                                                                                                                |
|---------------|------------|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                 |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                             |
| 31:4          | R          | R/W | 0x0     | PCED[31:4]<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     | PCED[3:0]<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.                                                                                                            |

### 22.6.9. HcControlHeadED Register

| Offset: 0x420 |            |    |         | Register Name: HcControlHeadED[CHED]<br>Default Value: 0x0                                                                                                                                                                                                              |
|---------------|------------|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                             |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                         |
| 31:4          | R/W        | R  | 0x0     | EHCD[31:4]<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     | EHCD[3:0]<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.                                                        |

### 22.6.10. HcControlCurrentED Register

| Offset: 0x424 |            |     |         | Register Name: HcControlCurrentED[CCED]<br>Default Value: 0x0                                                                                                                                                                                                                                |
|---------------|------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                  |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                              |
| 31:4          | R/W        | R/W | 0x0     | CCED[31:4]<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><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 | CCED[3:0]<br><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, bit 0 to bit 3, must be zero in this field.                                                                                                                                       |

### 22.6.11. HcBulkHeadED Register

| Offset: 0x428 |            |    |         | Register Name: HcBulkHeadED[BHED]<br>Default Value: 0x0                                                                                                                                                                                                          |
|---------------|------------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                      |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                  |
| 31:4          | R/W        | R  | 0x0     | BHED[31:4]<br><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     | BHED[3:0]<br><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, bit 0 to bit 3, must be zero in this field.                                                    |

### 22.6.12. HcBulkCurrentED Register

| Offset: 0x42c |            |     |         | Register Name: HcBulkCurrentED [BCED]<br>Default Value: 0x00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:4          | R/W        | R/W | 0x0     | BulkCurrentED[31:4]<br><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 ControlListFilled of HcControl. If set, it copies the content of HcBulkHeadED to HcBulkCurrentED and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the BulkListEnable of HcControl 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     | BulkCurrentED [3:0]<br><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. |
|--|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------|

### 22.6.13. HcDoneHead Register

| Offset: 0x430 |            |     |         | Register Name: HcDoneHead<br>Default Value: 0x00                                                                                                                                                                                                                                                                               |
|---------------|------------|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                    |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                |
| 31:4          | R          | R/W | 0x0     | HcDoneHead[31:4]<br>When a TD is completed, HC writes the content of HcDoneHead to the NextTD field of the TD. HC then overwrites the content of HcDoneHead 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 WritebackDoneHead of HcInterruptStatus. |
| 3:0           | R          | R   | 0x0     | HcDoneHead[3:0]<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, bit 0 to bit 3, must be zero in this field.                                                                                                                |

### 22.6.14. HcFmInterval Register

| Offset: 0x434 |            |    |         | Register Name: HcFmInterval Register<br>Default Value: 0x2EDF                                                                                                                                                                                                                                                                                                                                                              |
|---------------|------------|----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31            | R/W        | R  | 0x0     | FrameIntervalToggler<br>HCD toggles this bit whenever it loads a new value to FrameInterval.                                                                                                                                                                                                                                                                                                                               |
| 30:16         | R/W        | R  | 0x0     | FSLargestDataPacket<br>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD.                                                   |
| 15:14         | /          | /  | 0x0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13:0          | R/W        | R  | 0x2edf  | FrameInterval<br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the HostControllerReset field of HcCommandStatus 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. |

### 22.6.15. HcFmRemaining Register

| Offset: 0x438 |            |     |         | Register Name: HcFmRemaining<br>Default Value: 0x0                                                                                                                                                                                                                                                                                                |
|---------------|------------|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                       |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                   |
| 31            | R          | R/W | 0x0     | FrameRemaining Toggle<br>This bit is loaded from the FrameIntervalToggle field of HcFmInterval whenever FrameRemaining reaches 0. This bit is used by HCD for the synchronization between FrameInterval and FrameRemaining.                                                                                                                       |
| 30:14         | /          | /   | 0x0     | Reserved                                                                                                                                                                                                                                                                                                                                          |
| 13:0          | R          | RW  | 0x0     | FramRemaining<br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the FrameInterval value specified in HcFmInterval at the next bit time boundary. When entering the USBOPERATIONAL state, HC re-loads the content with the FrameInterval of HcFmInterval and uses the updated value from the next SOF. |

### 22.6.16. HcFmNumber Register

| Offset: 0x43c |            |     |         | Register Name: HcFmNumber<br>Default Value: 0x0                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|------------|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|               | HCD        | HC  |         |                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:16         |            |     |         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:0          | R          | R/W | 0x0     | FrameNumber<br>This is incremented when HcFmRemaining 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 FrameNumber 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 StartofFrame in HcInterruptStatus. |

### 22.6.17. HcPeriodicStart Register

| Offset: 0x440 |            |    |         | Register Name: HcPeriodicStatus<br>Default Value: 0x0 |
|---------------|------------|----|---------|-------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                           |
|               | HCD        | HC |         |                                                       |
| 31:14         |            |    |         | Reserved                                              |

|      |     |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13:0 | R/W | R | 0x0 | PeriodicStart<br>After hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from HcFmInterval. A typical value will be 0x2A3F. When HcFmRemaining 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. |
|------|-----|---|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 22.6.18. HcLSThreshold Register

| Offset: 0x444 |            |   |         | Register Name: HcLSThreshold<br>Default Value: 0x0628                                                                                                                                                                                                                                                      |
|---------------|------------|---|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |   | Default | Description                                                                                                                                                                                                                                                                                                |
| HCD           | HC         |   |         |                                                                                                                                                                                                                                                                                                            |
| 31:12         |            |   |         | Reserved                                                                                                                                                                                                                                                                                                   |
| 11:0          | R/W        | R | 0x0628  | LSThreshold<br>This field contains a value which is compared to the FrameRemaining field prior to initiating a Low Speed transaction. The transaction is started only if FrameRemaining <sup>3</sup> this field. The value is calculated by HCD with the consideration of transmission and setup overhead. |

### 22.6.19. HcRhDescriptorA Register

| Offset: 0x448 |                                                                        |   |         | Register Name: HcRhDescriptorA<br>Default Value:                                                                                                                                                                                                                                                                                                                                                                                                        |   |                                                                        |   |                                      |
|---------------|------------------------------------------------------------------------|---|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|--------------------------------------|
| Bit           | Read/Write                                                             |   | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                                                        |   |                                      |
| HCD           | HC                                                                     |   |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                                        |   |                                      |
| 31:24         | R/W                                                                    | R | 0x2     | PowerOnToPowerGoodTime[POTPGT]<br>This byte specifies the duration HCD has to wait before accessing a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.                                                                                                                                                                                                             |   |                                                                        |   |                                      |
| 23:13         |                                                                        |   |         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                                                        |   |                                      |
| 12            | R/W                                                                    | R | 1       | NoOverCurrentProtection<br>This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the OverCurrentProtectionMode field specifies global or per-port reporting.<br><table border="1" data-bbox="682 1796 1492 1931"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>No overcurrent protection supported.</td></tr> </table> | 0 | Over-current status is reported collectively for all downstream ports. | 1 | No overcurrent protection supported. |
| 0             | Over-current status is reported collectively for all downstream ports. |   |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                                        |   |                                      |
| 1             | No overcurrent protection supported.                                   |   |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                                        |   |                                      |
| 11            | R/W                                                                    | R | 0       | OverCurrentProtectionMode                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                      |

|     |                                                                                                                                                                                                                                                                                                                                                              |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                              |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                                                                                                                                                                                                                                                                                                                                                              |   |      | This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as PowerSwitchingMode. This field is valid only if the NoOverCurrentProtection field is cleared.<br><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  | Device Type<br><br>This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                              |
| 9   | R/W                                                                                                                                                                                                                                                                                                                                                          | R | 1    | PowerSwitchingMode<br><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 when the NoPowerSwitching field is cleared.<br><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 switch. If the PortPowerControlMask bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower).</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 switch. If the PortPowerControlMask bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower). |
| 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 switch. If the PortPowerControlMask bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower). |   |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                              |
| 8   | R/W                                                                                                                                                                                                                                                                                                                                                          | R | 0    | NoPowerSwitching<br><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 PowerSwitchingMode specifies global or per-port switching.<br><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 | NumberDownstreamPorts<br><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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                                                                                                                                                                                                                                                                                                                                              |

### 22.6.20. HcRhDescriptorB Register

|               |            |    |                                                           |             |
|---------------|------------|----|-----------------------------------------------------------|-------------|
| Offset: 0x44c |            |    | Register Name: HcRhDescriptorB Register<br>Default Value: |             |
| Bit           | Read/Write |    | Default                                                   | Description |
|               | HCD        | HC |                                                           |             |

|       |                                |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |          |      |                               |      |                               |     |  |       |                                |
|-------|--------------------------------|---|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
|       |                                |   |     | PortPowerControlMask<br><br>Each bit indicates if a port is affected by a global power control command when PowerSwitchingMode is set. When set, the port's power state is only affected by per-port power control (Set/ClearPortPower). When cleared, the port is controlled by the global power switch (Set/ClearGlobalPower). If the device is configured to global switching mode (PowerSwitchingMode = 0 ), this field is not valid.                     |      |          |      |                               |      |                               |     |  |       |                                |
| 31:16 | R/W                            | R | 0x0 | <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 | DeviceRemovable<br><br>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. <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.   |   |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |          |      |                               |      |                               |     |  |       |                                |

### 22.6.21. HcRhStatus Register

| Offset: 0x450 |            |    |         | Register Name: HcRhStatus Register<br>Default Value:                                                                                                                                                                                                                                                            |
|---------------|------------|----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |    | Default | Description                                                                                                                                                                                                                                                                                                     |
|               | HCD        | HC |         |                                                                                                                                                                                                                                                                                                                 |
| 31            | W          | R  | 0       | (write)ClearRemoteWakeUpEnable<br><br>Write a '1' clears DeviceRemoteWakeUpEnable. Write a '0' has no effect.                                                                                                                                                                                                   |
| 30:18         | /          | /  | 0x0     | Reserved                                                                                                                                                                                                                                                                                                        |
| 17            | R/W        | R  | 0       | OverCurrentIndicatorChange<br><br>This bit is set by hardware when a change has occurred to the OverCurrentIndicator field of this register. The HCD clears this bit by writing a '1'. Writing a '0' has no effect.                                                                                             |
| 16            | R/W        | R  | 0x0     | (read)LocalPowerStartusChange<br><br>The Root Hub does not support the local power status features, thus, this bit is always read as '0'.<br><br>(write)SetGlobalPower<br><br>In global power mode (PowerSwitchingMode=0), this bit is written to '1' to turn on power to all ports (clear PortPowerStatus). In |

|      |                                                   |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                   |   |                                               |
|------|---------------------------------------------------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------------------|---|-----------------------------------------------|
|      |                                                   |     |     | per-port power mode, it sets PortPowerStatus only on ports whose PortPowerControlMask bit is not set. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                   |   |                                               |
| 15   | R/W                                               | R   | 0x0 | (read)DeviceRemoteWakeupEnable<br>This bit enables a ConnectStatusChange bit as a resume event, causing a USBSUSPEND to USBRESUME state transition and setting the ResumeDetected interrupt.<br><table border="1" data-bbox="682 449 1492 539"> <tr> <td>0</td><td>ConnectStatusChange is not a remote wakeup event.</td></tr> <tr> <td>1</td><td>ConnectStatusChange is a remote wakeup event.</td></tr> </table>                                                                                                                                              | 0 | ConnectStatusChange is not a remote wakeup event. | 1 | ConnectStatusChange is a remote wakeup event. |
| 0    | ConnectStatusChange is not a remote wakeup event. |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                   |   |                                               |
| 1    | ConnectStatusChange is a remote wakeup event.     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                   |   |                                               |
| 14:2 |                                                   |     |     | (write)SetRemoteWakeupEnable<br>Writing a '1' sets DeviceRemoveWakeupEnable. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                                                   |   |                                               |
| 1    | R                                                 | R/W | 0x0 | Reserved<br><br>OverCurrentIndicator<br>This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal.<br>If per-port overcurrent protection is implemented this bit is always '0'                                                                                                                                                                                                                                                                 |   |                                                   |   |                                               |
| 0    | R/W                                               | R   | 0x0 | (Read)LocalPowerStatus<br>When read, this bit returns the LocalPowerStatus of the Root Hub. The Root Hub does not support the local power status feature; thus, this bit is always read as '0'.<br>(Write)ClearGlobalPower<br>When write, this bit is operated as the ClearGlobalPower. In global power mode (PowerSwitchingMode=0), This bit is written to '1' to turn off power to all ports (clear PortPowerStatus). In per-port power mode, it clears PortPowerStatus only on ports whose PortPowerControlMask bit is not set. Writing a '0' has no effect. |   |                                                   |   |                                               |

### 22.6.22. HcRhPortStatus Register

| Offset: 0x454 |                            |     | Register Name: HcRhPortStatus<br>Default Value: 0x100 |                                                                                                                                                                                                                                                                                                                                    |   |                            |   |                        |
|---------------|----------------------------|-----|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------|---|------------------------|
| Bit           | Read/Write                 |     | Default                                               | Description                                                                                                                                                                                                                                                                                                                        |   |                            |   |                        |
|               | HCD                        | HC  |                                                       |                                                                                                                                                                                                                                                                                                                                    |   |                            |   |                        |
| 31:21         | /                          | /   | 0x0                                                   | Reserved                                                                                                                                                                                                                                                                                                                           |   |                            |   |                        |
| 20            | R/W                        | R/W | 0x0                                                   | PortResetStatusChange<br>This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.<br><table border="1" data-bbox="682 1841 1492 1931"> <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                                                   | PortOverCurrentIndicatorChange                                                                                                                                                                                                                                                                                                     |   |                            |   |                        |

|       |                                       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
|-------|---------------------------------------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|---|--------------------------------------|
|       |                                       |     |     | This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when Root Hub changes the PortOverCurrentIndicator bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
|       |                                       |     |     | <table border="1"> <tr> <td>0</td><td>no change in PortOverCurrentIndicator</td></tr> <tr> <td>1</td><td>PortOverCurrentIndicator has changed</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0 | no change in PortOverCurrentIndicator | 1 | PortOverCurrentIndicator has changed |
| 0     | no change in PortOverCurrentIndicator |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1     | PortOverCurrentIndicator has changed  |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 18    | R/W                                   | R/W | 0x0 | <p>PortSuspendStatusChange</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 ResetStatusChange 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>PortEnableStatusChange</p> <p>This bit is set when hardware events cause the PortEnableStatus 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 PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table>                                                                                                                                                                                                                                                                                                                                 | 0 | no change in PortEnableStatus         | 1 | change in PortEnableStatus           |
| 0     | no change in PortEnableStatus         |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1     | change in PortEnableStatus            |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 16    | R/W                                   | R/W | 0x0 | <p>ConnectStatusChange</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 CurrentConnectStatus is cleared when a SetPortReset, SetPortEnable, or SetPortSuspend 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 PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table> <p>Note: If the DeviceRemovable[NDP] bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</p> | 0 | no change in PortEnableStatus         | 1 | change in PortEnableStatus           |
| 0     | no change in PortEnableStatus         |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1     | change in PortEnableStatus            |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 15:10 | /                                     | /   | 0x0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                       |   |                                      |
| 9     | R/W                                   | R/W | -   | <p>(read)LowSpeedDeviceAttached</p> <p>This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When cleared, a Full Speed device is attached to this port. This field is valid only when the CurrentConnectStatus 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>                                                                                                                                                                                                                                                                                | 0 | full speed device attached            | 1 | low speed device attached            |
| 0     | full speed device attached            |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1     | low speed device attached             |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |

|     |                                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
|-----|---------------------------------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|-----------------------------|
|     |                                 |     |     | (write)ClearPortPower<br>The HCD clears the PortPowerStatus bit by writing a '1' to this bit. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
|     |                                 |     |     | (read)PortPowerStatus<br>This bit reflects the port's power status, irrelevant of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing SetPortPower or SetGlobalPower. HCD clears this bit by writing ClearPortPower or ClearGlobalPower. Which power control switches are enabled is determined by PowerSwitchingMode and PortPortControlMask[NumberDownstreamPort]. In global switching mode(PowerSwitchingMode=0), only Set/ClearGlobalPower controls this bit. In per-port power switching (PowerSwitchingMode=1), if the PortPowerControlMask[NDP] bit for the port is set, only Set/ClearPortPower commands are enabled. If the mask is not set, only Set/ClearGlobalPower commands are enabled. When port power is disabled, CurrentConnectStatus, PortEnableStatus, PortSuspendStatus, and PortResetStatus should be reset.<br><table border="1" data-bbox="682 988 1492 1078"> <tr> <td>0</td><td>port power is off</td></tr> <tr> <td>1</td><td>port power is on</td></tr> </table> | 0 | port power is off               | 1 | port power is on            |
| 0   | port power is off               |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 1   | port power is on                |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 8   | R/W                             | R/W | 0x1 | (write)SetPortPower<br>The HCD writes a '1' to set the PortPowerStatus bit. Writing a '0' has no effect.<br>Note: This bit is always read as '1b' if power switching is not supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |                                 |   |                             |
| 7:5 | /                               | /   | 0x0 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |                                 |   |                             |
|     |                                 |     |     | (read)PortResetStatus<br>When this bit is set by writing to SetPortReset, port reset signaling is asserted. When reset is completed, this bit is cleared when PortResetStatusChange is set. This bit cannot be set if CurrentConnectStatus is cleared.<br><table border="1" data-bbox="682 1572 1492 1662"> <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>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 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     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 4   | R/W                             | R/W | 0x0 | (write)SetPortReset<br>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortResetStatus, but instead sets ConnectStatusChange. This informs the driver that it attempted to reset a disconnected port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                 |   |                             |
| 3   | R/W                             | R/W | 0x0 | (read)PortOverCurrentIndicator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                 |   |                             |

|   |                                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
|---|---------------------------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------|---|---------------------------------|
|   |                                 |     |     | 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. <table border="1" data-bbox="682 444 1500 534"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table><br>(write)ClearSuspendStatus<br>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if PortSuspendStatus is set.                                                                                                                                                                                                                                                        | 0 | no overcurrent condition. | 1 | overcurrent condition detected. |
| 0 | no overcurrent condition.       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
| 1 | overcurrent condition detected. |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
| 2 | R/W                             | R/W | 0x0 | (read)PortSuspendStatus<br>This bit indicates the port is suspended or in the resume sequence. It is set by a SetSuspendState write and cleared when PortSuspendStatusChange is set at the end of the resume interval. This bit cannot be set if CurrentConnectStatus is cleared. This bit is also cleared when PortResetStatusChange 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. <table border="1" data-bbox="682 1089 1500 1179"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table><br>(write)SetPortSuspend<br>The HCD sets the PortSuspendStatus bit by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortSuspendStatus; instead it sets ConnectStatusChange. This informs the driver that it attempted to suspend a disconnected port. | 0 | port is not suspended     | 1 | port is suspended               |
| 0 | port is not suspended           |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
| 1 | port is suspended               |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
| 1 | R/W                             | R/W | 0x0 | (read)PortEnableStatus<br>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 PortEnabledStatusChange to be set. HCD sets this bit by writing SetPortEnable and clears it by writing ClearPortEnable. This bit cannot be set when CurrentConnectStatus is cleared. This bit is also set, if not already, at the completion of a port reset when ResetStatusChange is set or port suspend when SuspendStatusChange is set. <table border="1" data-bbox="682 1875 1500 1965"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table>                                                                                                                                                                                                                | 0 | port is disabled          | 1 | port is enabled                 |
| 0 | port is disabled                |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |
| 1 | port is enabled                 |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                           |   |                                 |

|   |                     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                     |   |                  |
|---|---------------------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---|------------------|
|   |                     |     |     | (write)SetPortEnable<br>The HCD sets PortEnableStatus by writing a '1'. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortEnableStatus, and sets ConnectStatusChange instead. This informs the driver that it attempts to enable a disconnected Port.                                                                                                                                                                                                                                                      |   |                     |   |                  |
| 0 | R/W                 | R/W | 0x0 | (read)CurrentConnectStatus<br>This bit reflects the current state of the downstream port.<br><table border="1" data-bbox="682 572 1500 662"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table><br>(write)ClearPortEnable<br>The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' has no effect. The CurrentConnectStatus is not affected by any write.<br>Note: This bit is always read as '1' when the attached device is non-removable(DviceRemoveable[NumberDownstreamPort]). | 0 | No device connected | 1 | Device connected |
| 0 | No device connected |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                     |   |                  |
| 1 | Device connected    |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |                     |   |                  |

## 22.7. USB Host Special Requirement

### 22.7.1. USB Host Clock Requirment

| Name   | Description                                                              |
|--------|--------------------------------------------------------------------------|
| HCLK   | System clock (provided by AHB bus clock). This clock needs to be >30MHz. |
| CLK60M | Clock from PHY for HS SIE, is constant to be 60MHz.                      |
| CLK48M | Clock from PLL for FS/LS SIE, is constant to be 48MHz.                   |

## 23. Digital Audio Interface

### 23.1. Overview

The Digital Audio Interface can be configured as I2S interface or PCM interface by software. When configured as I2S interface, it can support the industry standard format for I2S, left-justified, or right-justified. PCM is a standard method used to digital audio for transmission over digital communication channels. It supports linear 13 or 16-bits linear, or 8-bit u-law or A-law companded sample formats at 8K samples/s and can receive and transmit on any selection of four of the first four slots following PCM\_SYNC.

It features:

- I2S or PCM configured by software
- Full-duplex synchronous serial interface
- Configurable Master / Slave Mode operation
- Audio data resolutions of 16, 20, 24
- I2S Audio data sample rate from 8Khz to 192Khz
- I2S Data format for standard I2S, Left Justified and Right Justified
- I2S supports 2 channel output and 2 channel input
- PCM supports linear sample (8-bits or 16-bits), 8-bits u-law and A-law companded sample
- One 128x24-bits FIFO for data transmit, one 64x24-bits FIFO for data receiving
- Programmable FIFO thresholds
- Support Interrupt and DMA
- Two 32-bit Counters for AVS application
- Loopback mode for test

### 23.2. Digital Audio Block Diagram



Figure23-1 Digital Audio Interface Block Diagram

### 23.3. Digital Audio Interface Timing Diagram



Figure 23-2 Standard I2S Timing Diagram



Figure 23-3 I2S Left-justified Timing Diagram



Figure 23-4 I2S Right-justified Timing Diagram



Figure 23-5 PCM Long Frame SYNC Timing Diagram



Figure 23-6 PCM Short Frame SYNC Timing Diagram

## 23.4. Digital Audio Interface Register List

| Module Name | Base Address |
|-------------|--------------|
| DA          | 0x01C22400   |

| Register Name | Offset | Description                               |
|---------------|--------|-------------------------------------------|
| DA_CTL        | 0x00   | Digital Audio Control Register            |
| DA_FAT0       | 0x04   | Digital Audio Format Register 0           |
| DA_FAT1       | 0x08   | Digital Audio Format Register 1           |
| DA_TXFIFO     | 0x0C   | Digital Audio TX FIFO Register            |
| DA_RXFIFO     | 0x10   | Digital Audio RX FIFO Register            |
| DA_FCTL       | 0x14   | Digital Audio FIFO Control Register       |
| DA_FSTA       | 0x18   | Digital Audio FIFO Status Register        |
| DA_INT        | 0x1C   | Digital Audio Interrupt Control Register  |
| DAISTA        | 0x20   | Digital Audio Interrupt Status Register   |
| DA_CLKD       | 0x24   | Digital Audio Clock Divide Register       |
| DA_TXCNT      | 0x28   | Digital Audio RX Sample Counter Register  |
| DA_RXCNT      | 0x2C   | Digital Audio TX Sample Counter Register  |
| DA_TXCHSEL    | 0x30   | Digital Audio TX Channel Select register  |
| DA_TXCHMAP    | 0x34   | Digital Audio TX Channel Mapping Register |

## 23.5. Digital Audio Interface Register Description

### 23.5.1. Digital Audio Control Register

|              |            |         |                                                     |
|--------------|------------|---------|-----------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: DA_CTL<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                         |
| 31:9         | /          | /       | /                                                   |
| 8            | R/W        | 0       | SDO_EN<br>0: Disable<br>1: Enable                   |

|   |     |   |                                                                                                                                |
|---|-----|---|--------------------------------------------------------------------------------------------------------------------------------|
| 7 | /   | / | /                                                                                                                              |
| 6 | R/W | 0 | ASS<br>Audio sample select when TX FIFO under run<br>0: Sending zero<br>1: Sending last audio sample                           |
| 5 | R/W | 0 | MS<br>Master Slave Select<br>0: Master<br>1: Slave                                                                             |
| 4 | R/W | 0 | PCM<br>0: I2S Interface<br>1: PCM Interface                                                                                    |
| 3 | R/W | 0 | LOOP<br>Loop back test<br>0: Normal mode<br>1: Loop back test<br>When set '1', connecting the SDO with the SDI in Master mode. |
| 2 | R/W | 0 | TXEN<br>Transmitter Block Enable<br>0: Disable<br>1: Enable                                                                    |
| 1 | R/W | 0 | RXEN<br>Receiver Block Enable<br>0: Disable<br>1: Enable                                                                       |
| 0 | R/W | 0 | GEN<br>Globe Enable<br>A disable on this bit overrides any other block or channel enables.<br>0: Disable<br>1: Enable          |

### 23.5.2. Digital Audio Format Register 0

| Offset: 0x04 |            |         | Register Name: DA_FAT0<br>Default Value: 0x0000_000C                                                                                                                                                                       |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                |
| 31:8         | /          | /       | /                                                                                                                                                                                                                          |
| 7            | R/W        | 0       | LRCP<br>Left/ Right Clock Parity<br>0: Normal<br>1: Inverted<br>In DSP/ PCM mode<br>0: MSB is available on 2nd BCLK rising edge after LRC rising edge<br>1: MSB is available on 1st BCLK rising edge after LRC rising edge |

|     |     |     |                                                                                                                                 |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------|
| 6   | R/W | 0   | BCP<br>BCLK Parity<br>0: Normal<br>1: Inverted                                                                                  |
| 5:4 | R/W | 0   | SR<br>Sample Resolution<br>00: 16-bits<br>01: 20-bits<br>10: 24-bits<br>11: Reserved                                            |
| 3:2 | R/W | 0x3 | WSS<br>Word Select Size<br>00: 16 BCLK<br>01: 20 BCLK<br>10: 24 BCLK<br>11: 32 BCLK                                             |
| 1:0 | R/W | 0   | FMT<br>Serial Data Format<br>00: Standard I2S Format<br>01: Left Justified Format<br>10: Right Justified Format<br>11: Reserved |

### 23.5.3. Digital Audio Format Register 1

| Offset: 0x08 |            |         | Register Name: DA_FAT1<br>Default Value: 0x0000_4020                                                                                                                   |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                            |
| 31:15        | /          | /       | /                                                                                                                                                                      |
| 14:12        | R/W        | 0x4     | PCM SYNC Period Clock Number<br>000: 16 BCLK period<br>001: 32 BCLK period<br>010: 64 BCLK period<br>011: 128 BCLK period<br>100: 256 BCLK period<br>Others : Reserved |
| 11           | R/W        | 0       | PCM Sync Out<br>0: Enable PCM_SYNC output in Master mode<br>1: Suppress PCM_SYNC whilst keep PCM_CLK running. Some Codec utilize this to enter a low power state.      |
| 10           | R/W        | 0       | PCM Out Mute<br>Write 1 force PCM_OUT to 0                                                                                                                             |
| 9            | R/W        | 0       | MLS<br>MSB / LSB First Select                                                                                                                                          |

|     |     |   |                                                                                                                                                                                                                                                                                                                                       |
|-----|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 0: MSB First<br>1: LSB First                                                                                                                                                                                                                                                                                                          |
| 8   | R/W | 0 | SEXT<br>Sign Extend (only for 16 bits slot)<br>0: Zeros or audio gain padding at LSB position<br>1: Sign extension at MSB position<br>When write the bit to 0, the unused bits are audio gain for 13-bit linear sample and zeros padding for 8-bit companding sample.<br>When write the bit to 1, the unused bits are sign extension. |
| 7:6 | R/W | 0 | SI<br>Slot Index<br>00: the 1st slot<br>01: the 2nd slot<br>10: the 3rd slot<br>11: the 4th slot                                                                                                                                                                                                                                      |
| 5   | R/W | 1 | SW<br>Slot Width<br>0: 8 clocks width<br>1: 16 clocks width<br>Note: For A-law or u-law PCM sample, if this bit is set to 1, eight zero bits are following with PCM sample.                                                                                                                                                           |
| 4   | R/W | 0 | SSYNC<br>Short Sync Select<br>0: Long Frame Sync<br>1: Short Frame Sync<br>It should be set '1' for 8 clocks width slot.                                                                                                                                                                                                              |
| 3:2 | R/W | 0 | RX PDM<br>PCM Data Mode<br>00: 16-bits Linear PCM<br>01: 8-bits Linear PCM<br>10: 8-bits u-law<br>11: 8-bits A-law                                                                                                                                                                                                                    |
| 1:0 | R/W | 0 | TX PDM<br>PCM Data Mode<br>00: 16-bits Linear PCM<br>01: 8-bits Linear PCM<br>10: 8-bits u-law<br>11: 8-bits A-law                                                                                                                                                                                                                    |

#### 23.5.4. Digital Audio TX FIFO register

| Offset: 0x0C |            |         | Register Name: DA_TXFIFO<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|--------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                            |

|      |   |   |                                                                                                                                                                                |
|------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | W | 0 | TX Sample<br>Transmitting left, right channel sample data should be written this register one by one. The left channel sample data is first and then the right channel sample. |
|------|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 23.5.5. Digital Audio RX FIFO register

| Offset: 0x10 |            |         | Register Name: DA_RXFIFO<br>Default Value: 0x0000_0000                                                                                  |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                             |
| 31:0         | R          | 0       | RX Sample<br>Host can get one sample by reading this register. The left channel sample data is first and then the right channel sample. |

### 23.5.6. Digital Audio FIFO Control Register

| Offset: 0x14 |            |         | Register Name: DA_FCTL<br>Default Value: 0x0004_00F0                                                                                 |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                          |
| 31           | R/W        | 0       | FIFOSRC<br>TX FIFO source select<br>0: APB bus<br>1: Analog Audio CODEC                                                              |
| 30:26        | /          | /       | /                                                                                                                                    |
| 25           | R/W        | 0       | FTX<br>Write '1' to flush TX FIFO, self cleared to '0'.                                                                              |
| 24           | R/W        | 0       | FRX<br>Write '1' to flush RX FIFO, self cleared to '0'.                                                                              |
| 23:19        | /          | /       | /                                                                                                                                    |
| 18:12        | R/W        | 0x40    | TXTL<br>TX FIFO 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>RX FIFO Trigger Level<br>Interrupt and DMA request trigger level for RXFIFO normal condition<br>Trigger Level = RXTL + 1     |
| 3            | /          | /       | /                                                                                                                                    |
| 2            | R/W        | 0       | TXIM<br>TX FIFO 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 |

|     |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | Example for 20-bits transmitted audio sample:<br>Mode 0: FIFO_I[23:0] = {4'h0, TXFIFO[31:12]}<br>Mode 1: FIFO_I[23:0] = {4'h0, TXFIFO[19:0]}                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1:0 | R/W | 0 | <p>RXOM<br/>RX FIFO Output Mode (Mode 0, 1, 2, 3)<br/>00: Expanding '0' at LSB of DA_RXFIFO register.<br/>01: Expanding received sample sign bit at MSB of DA_RXFIFO register.<br/>10: Truncating received samples at high half-word of DA_RXFIFO register and low half-word of DA_RXFIFO register is filled by '0'.<br/>11: Truncating received samples at low half-word of DA_RXFIFO register and high half-word of DA_RXFIFO register is expanded by its sign bit.</p> <p>Example for 20-bits received audio sample:<br/>Mode 0: RXFIFO[31:0] = {FIFO_O[19:0], 12'h0}<br/>Mode 1: RXFIFO[31:0] = {12{FIFO_O[19]}, FIFO_O[19:0]}<br/>Mode 2: RXFIFO[31:0] = {FIFO_O[19:4], 16'h0}<br/>Mode 3: RXFIFO[31:0] = {16{FIFO_O[19]}, FIFO_O[19:4]}</p> |

### 23.5.7. Digital Audio FIFO Status Register

| Offset: 0x18 |            |         | Register Name: DA_FSTA<br>Default Value: 0x1080_0000                                                                                     |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                              |
| 31:29        | /          | /       | /                                                                                                                                        |
| 28           | R          | 1       | <p>TXE<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 (&gt;= 1 word)</p> |
| 27:24        | /          | /       | /                                                                                                                                        |
| 23:16        | R          | 0x80    | TXE_CNT<br>TX FIFO Empty Space Word Counter                                                                                              |
| 15:9         | /          | /       | /                                                                                                                                        |
| 8            | R          | 0       | <p>RXA<br/>RX FIFO Available<br/>0: No available data in RX FIFO<br/>1: More than one sample in RX FIFO (&gt;= 1 word)</p>               |
| 7            | /          | /       | /                                                                                                                                        |
| 6:0          | R          | 0       | RXA_CNT<br>RX FIFO Available Sample Word Counter                                                                                         |

### 23.5.8. Digital Audio DMA & Interrupt Control Register

|              |                                                     |
|--------------|-----------------------------------------------------|
| Offset: 0x1C | Register Name: DA_INT<br>Default Value: 0x0000_0000 |
|--------------|-----------------------------------------------------|

| Bit  | Read/Write | Default | Description                                                                                                                                                     |
|------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /          | /       | /                                                                                                                                                               |
| 7    | R/W        | 0       | TX_DRQ<br>TX FIFO Empty DRQ Enable<br>0: Disable<br>1: Enable                                                                                                   |
| 6    | R/W        | 0       | TXUI_EN<br>TX FIFO Under run Interrupt Enable<br>0: Disable<br>1: Enable                                                                                        |
| 5    | R/W        | 0       | TXOI_EN<br>TX FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable<br>When set to '1', an interrupt occurs if writing new audio data when TX FIFO is full.  |
| 4    | R/W        | 0       | TXEI_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                                                            |
| 3    | R/W        | 0       | RX_DRQ<br>RX FIFO Data Available DRQ Enable<br>0: Disable<br>1: Enable<br>When set to '1', RXFIFO DMA Request line is asserted if Data is available in RX FIFO. |
| 2    | R/W        | 0       | RXUI_EN<br>RX FIFO Underrun Interrupt Enable<br>0: Disable<br>1: Enable                                                                                         |
| 1    | R/W        | 0       | RXOI_EN<br>RX FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable                                                                                          |
| 0    | R/W        | 0       | RXAI_EN<br>RX FIFO Data Available Interrupt Enable<br>0: Disable<br>1: Enable                                                                                   |

### 23.5.9. Digital Audio Interrupt Status Register

| Offset: 0x20 |            |         | Register Name: DAISTA<br>Default Value: 0x0000_0010 |
|--------------|------------|---------|-----------------------------------------------------|
| Bit          | Read/Write | Default | Description                                         |

|      |     |   |                                                                                                                                                                                                   |
|------|-----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | /   | / | /                                                                                                                                                                                                 |
| 6    | R/W | 0 | TXU_INT<br>TX FIFO Under run Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Under run Pending Interrupt                                                                                  |
| 5    | R/W | 0 | TXO_INT<br>TX FIFO Overrun Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Overrun Pending Interrupt<br>Write '1' to clear this interrupt                                                 |
| 4    | R/W | 1 | 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 cleared if interrupt condition fails.    |
| 3:2  | /   | / | /                                                                                                                                                                                                 |
| 1    | R/W | 0 | RXO_INT<br>RX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt                                                             |
| 0    | R/W | 0 | 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 cleared if interrupt condition fails. |

### 23.5.10. Digital Audio Clock Divide Register

| Offset: 0x24 |            |         | Register Name: DA_CLKD<br>Default Value: 0x0000_0000                                                                                                   |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                            |
| 31:8         | /          | /       | /                                                                                                                                                      |
| 7            | R/W        | 0       | MCLKO_EN<br>0: Disable MCLK Output<br>1: Enable MCLK Output<br>Notes: Both in Slave and Master mode, when this bit is set to 1, MCLK should be output. |
| 6:4          | R/W        | 0       | BCLKDIV<br>BCLK Divide Ratio from MCLK<br>000: Divide by 2 (BCLK = MCLK/2)<br>001: Divide by 4                                                         |

|     |     |   |                                                                                                                                                                                                                                                                                                                      |
|-----|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 010: Divide by 6<br>011: Divide by 8<br>100: Divide by 12<br>101: Divide by 16<br>110: Divide by 32<br>111: Divide by 64                                                                                                                                                                                             |
| 3:0 | R/W | 0 | MCLKDIV<br>MCLK Divide Ratio from Audio PLL Output<br>0000: Divide by 1<br>0001: Divide by 2<br>0010: Divide by 4<br>0011: Divide by 6<br>0100: Divide by 8<br>0101: Divide by 12<br>0110: Divide by 16<br>0111: Divide by 24<br>1000: Divide by 32<br>1001: Divide by 48<br>1010: Divide by 64<br>Others : Reserved |

### 23.5.11. Digital Audio TX Counter register

| Offset: 0x28 |            |         | Register Name: DA_TXCNT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                 |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                           |
| 31:0         | R/W        | 0       | TX Sample Counter<br>The audio sample number of sending into TXFIFO. When one sample is put into TXFIFO by DMA or by host IO, the TX sample counter register increases by one. The TX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count on base of this initial value. |

### 23.5.12. Digital Audio RX Counter register

| Offset: 0x2C |            |         | Register Name: DA_RXCNT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                     |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                               |
| 31:0         | R/W        | 0       | RX Sample Counter<br>The audio sample number of writing into RXFIFO. When one sample is written by Digital Audio Engine, the RX sample counter register increases by one. The RX sample counter register can be set to any initial value at any time. After being updated by the initial value, the counter register should count on base of this initial |

|  |  |  |        |
|--|--|--|--------|
|  |  |  | value. |
|--|--|--|--------|

### 23.5.13. Digital Audio TX Channel Select register

|              |            |         |                                                         |
|--------------|------------|---------|---------------------------------------------------------|
| Offset: 0x30 |            |         | Register Name: DA_TXCHSEL<br>Default Value: 0x0000_0001 |
| Bit          | Read/Write | Default | Description                                             |
| 31:3         | /          | /       | /                                                       |
|              |            |         | Channel_select<br>0: 1-ch<br>1: 2-ch                    |
| 2:0          | R/W        | 1       | Others: Reserved                                        |

### 23.5.14. Digital Audio TX Channel Mapping Register

|              |            |         |                                                                    |
|--------------|------------|---------|--------------------------------------------------------------------|
| Offset: 0x34 |            |         | Register Name: DA_TXCHMAP<br>Default Value: 0x7654_3210            |
| Bit          | Read/Write | Default | Description                                                        |
| 31:7         | /          | /       | /                                                                  |
| 6:4          | R/W        | 1       | CH1_MAP:<br>000: 1st sample<br>001: 2nd sample<br>Others: Reserved |
| 3            | /          | /       | /                                                                  |
| 2:0          | R/W        | 0       | CH0_MAP:<br>000: 1st sample<br>001: 2nd sample<br>Others: Reserved |

### 23.5.15. Digital Audio RX Channel Select register

|              |            |         |                                                            |
|--------------|------------|---------|------------------------------------------------------------|
| Offset: 0x38 |            |         | Register Name: DA_RXCHSEL<br>Default Value: 0x0000_0001    |
| Bit          | Read/Write | Default | Description                                                |
| 31:3         | /          | /       | Reserved                                                   |
|              |            |         | Channel_select<br>0: 1-ch<br>1: 2-ch<br>2: 3-ch<br>3: 4-ch |
| 2:0          | R/W        | 1       | Others: Reserved                                           |

### 23.5.16. Digital Audio RX Channel Mapping Register

|              |                                                         |
|--------------|---------------------------------------------------------|
| Offset: 0x3C | Register Name: DA_RXCHMAP<br>Default Value: 0x0000_3210 |
|--------------|---------------------------------------------------------|

| Bit   | Read/Write | Default | Description                                                                                              |
|-------|------------|---------|----------------------------------------------------------------------------------------------------------|
| 31:15 | /          | /       | /                                                                                                        |
| 14:12 | R/W        | 3       | CH3_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>Others: Reserved |
| 11    | /          | /       | /                                                                                                        |
| 10:8  | R/W        | 2       | CH2_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>Others: Reserved |
| 7     | /          | /       | /                                                                                                        |
| 6:4   | R/W        | 1       | CH1_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>Others: Reserved |
| 3     | /          | /       | /                                                                                                        |
| 2:0   | R/W        | 0       | CH0_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>Others: Reserved |

## 23.6. Digital Audio Interface Special Requirement

### 23.6.1. Digital Audio Interface Pin List

| Port Name | Width | Direction(M) | Description                           |
|-----------|-------|--------------|---------------------------------------|
| DA_BCLK   | 1     | IN/OUT       | Digital Audio Serial Clock            |
| DA_LRC    | 1     | IN/OUT       | Digital Audio Sample Rate Clock/ Sync |
| DA_SDO    | 1     | OUT          | Digital Audio Serial Data Output      |
| DA_SDI    | 1     | IN           | Digital Audio Serial Data Input       |
| DA_MCLK   | 1     | OUT          | Digital Audio MCLK Output             |

### 23.6.2. Digital Audio Interface MCLK and BCLK

The Digital Audio Interface can support sampling rates from 128fs to 768fs, and fs is the audio sampling frequency typicaling 32kHz, 44.1kHz, 48kHz or 96kHz. For different sampling frequencies,

A10s User Manual V1.40

Copyright © 2015 Allwinner Technology. All Rights Reserved.  
2015.04.22

the tables list the coefficient value of MCLKDIV and BCLKDIV.

| <b>Sampling Rate<br/>(kHz)</b> | <b>128fs</b> | <b>192fs</b> | <b>256fs</b> | <b>384fs</b> | <b>512fs</b> | <b>768fs</b> |
|--------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|
| 8                              | 24           | 16           | 12           | 8            | 6            | 4            |
| 16                             | 12           | 8            | 6            | 4            | X            | 2            |
| 32                             | 6            | 4            | X            | 2            | X            | 1            |
| 64                             | X            | 2            | X            | 1            | X            | X            |
| 128                            | X            | 1            | X            | X            | X            | X            |
| 12                             | 16           | X            | 8            | X            | 4            | X            |
| 24                             | 8            | X            | 4            | X            | 2            | X            |
| 48                             | 4            | X            | 2            | X            | 1            | X            |
| 96                             | 2            | X            | 1            | X            | X            | X            |
| 192                            | 1            | X            | X            | X            | X            | X            |

Table 23-1 MCLKDIV value for 24.576MHz Audio Serial Frequency

| <b>Sampling Rate<br/>(kHz)</b> | <b>128fs</b> | <b>192fs</b> | <b>256fs</b> | <b>384fs</b> | <b>512fs</b> | <b>768fs</b> |
|--------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|
| 11.025                         | 16           | X            | 8            | X            | 4            | X            |
| 22.05                          | 8            | X            | 4            | X            | 2            | X            |
| 44.1                           | 4            | X            | 2            | X            | 1            | X            |
| 88.2                           | 2            | X            | 1            | X            | X            | X            |
| 176.4                          | 1            | X            | X            | X            | X            | X            |

Table 23-2 MCLKDIV value for 22.5792 MHz Audio Serial Frequency

| <b>Word Select Size</b> | <b>128fs</b> | <b>192fs</b> | <b>256fs</b> | <b>384fs</b> | <b>512fs</b> | <b>768fs</b> |
|-------------------------|--------------|--------------|--------------|--------------|--------------|--------------|
| 16                      | 4            | 6            | 8            | 12           | 16           | X            |
| 24                      | X            | 4            | X            | 8            | X            | 16           |
| 32                      | 2            | X            | 4            | 6            | 8            | 12           |

Table 23-3 BCLKDIV value for Different Word Select Size

### 23.6.3. Digital Audio Interface Clock Source and Frequency

There are two clocks for Digital Audio Interface: one is from APB bus and the other is from Audio PLL.

| <b>Name</b> | <b>Description</b>                                                                                                       |
|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Audio_PLL   | 24.576Mhz or 22.528Mhz generated by Audio PLL                                                                            |
| APB_CLK     | APB bus system clock.<br>In I2S mode, it is requested $\geq 0.25$ BCLK.<br>In PCM mode, it is requested $\geq 0.5$ BCLK. |

## 24. Ethernet MAC

### 24.1. Overview

The Ethernet MAC Controller enables the host to transmit and receive data over Ethernet in compliance to the IEEE 802.3-2002 standard. It supports 10M/100M external PHY with MII interface in both full and half duplex modes, and supports a 16K byte SRAM for continuous data transmission, flow control as well as DA/SA filtering.

The Ethernet MAC Controller (EMAC) features:

- Compatible with IEEE802.3 standards
- Support 10/100Mbps data rate
- Support full and half duplex operations
- Support IEEE 802.3x flow control for full-duplex operation
- Support back-pressure flow control for half-duplex operation
- Support DA/SA Filtering
- Support Loop back operations
- Provide MII Interface for external Ethernet PHY
- 3K Bytes FIFO for TX
- 13K Bytes FIFO for RX

# 25. Transport Stream Controller

## 25.1. Overview

The transport stream controller (TSC) is responsible for de-multiplexing and pre-processing the inputting multimedia data defined in ISO/IEC 13818-1. It receives multimedia data stream from SSI (Synchronous Serial Port)/SPI (Synchronous Parallel Port) inputs and de-multiplexes the data into Packets by PID (Packet Identify), and then the Packet will be stored to memory by DMA.

The TS controller can be used for almost all multimedia applications, for example, DVB STB, IPTV, Streaming-media Box, multimedia players, etc.

The following figure is the Top Diagram of TSC.



Figure 25-1 Transport Controller Block Diagram  
(TSC – TS Controller, TSF – TS Filter, TSD – TS Descrambler, TSG – TS Generator)

It features:

- One external Synchronous Parallel Interface (SPI) or one external Synchronous Serial Interface (SSI) for DTV Application
- 32 Channels PID Filter
- Support Multiple Transport Stream Packet (188, 192, 204) Format
- Configurable SPI And SSI Timing Parameters
- Hardware Packet Synchronous Byte Error Detection
- Hardware PCR Packet Detection
- Configurable SPI Transport Stream Generator For Streams In DRAM Memory
- Support DMA For Data Transfer

## 25.2. TS Register List

| <b>Module Name</b> | <b>Base Address</b> |
|--------------------|---------------------|
| TSC_BASE           | 0x01c04000          |
| TSG OFFSET         | 0x00000040          |
| TSF0 OFFSET        | 0x00000080          |
| TSF1 OFFSET        | 0x00000100          |

| <b>Register Name</b> | <b>Offset</b> | <b>Description</b>                         |
|----------------------|---------------|--------------------------------------------|
| TSC_CTLR             | TSC + 0x00    | TSC Control Register                       |
| TSC_STAR             | TSC + 0x04    | TSC Status Register                        |
| TSC_PCTRLR           | TSC + 0x10    | TSC Port Control Register                  |
| TSC_PPARR            | TSC + 0x14    | TSC Port Parameter Register                |
| TSC_TSFMUXR          | TSC + 0x20    | TSC TSF Input Multiplex Control Register   |
| TSC_OUTMUXR          | TSC + 0x28    | TSC Port Output Multiplex Control Register |
| TSG_CTLR             | TSG + 0x00    | TSG Control Register                       |
| TSG_PPR              | TSG + 0x04    | TSG Packet Parameter Register              |
| TSG_STAR             | TSG + 0x08    | TSG Status Register                        |
| TSG_CCR              | TSG + 0x0c    | TSG Clock Control Register                 |
| TSG_BBAR             | TSG + 0x10    | TSG Buffer Base Address Register           |
| TSG_BSZR             | TSG + 0x14    | TSG Buffer Size Register                   |
| TSG_BPR              | TSG + 0x18    | TSG Buffer Pointer Register                |
| TSF_CTLR             | TSF + 0x00    | TSF Control Register                       |
| TSF_PPR              | TSF + 0x04    | TSF Packet Parameter Register              |
| TSF_STAR             | TSF + 0x08    | TSF Status Register                        |
| TSF_DIER             | TSF + 0x10    | TSF DMA Interrupt Enable Register          |
| TSF_OIER             | TSF + 0x14    | TSF Overlap Interrupt Enable Register      |
| TSF_DISR             | TSF + 0x18    | TSF DMA Interrupt Status Register          |
| TSF_OISR             | TSF + 0x1c    | TSF Overlap Interrupt Status Register      |
| TSF_PCCR             | TSF + 0x20    | TSF PCR Control Register                   |
| TSF_PCDR             | TSF + 0x24    | TSF PCR Data Register                      |
| TSF_CENR             | TSF + 0x30    | TSF Channel Enable Register                |
| TSF_CPER             | TSF + 0x34    | TSF Channel PES Enable Register            |
| TSF_CDER             | TSF + 0x38    | TSF Channel Descramble Enable Register     |
| TSF_CINDR            | TSF + 0x3c    | TSF Channel Index Register                 |
| TSF_CCTRLR           | TSF + 0x40    | TSF Channel Control Register               |
| TSF_CSTAR            | TSF + 0x44    | TSF Channel Status Register                |
| TSF_CCWIR            | TSF + 0x48    | TSF Channel CW Index Register              |
| TSF_CPIDR            | TSF + 0x4c    | TSF Channel PID Register                   |
| TSF_CBBAR            | TSF + 0x50    | TSF Channel Buffer Base Address Register   |
| TSF_CBSZR            | TSF + 0x54    | TSF Channel Buffer Size Register           |
| TSF_CBWPR            | TSF + 0x58    | TSF Channel Buffer Write Pointer Register  |

|           |            |                                          |
|-----------|------------|------------------------------------------|
| TSF_CBRPR | TSF + 0x5c | TSF Channel Buffer Read Pointer Register |
|-----------|------------|------------------------------------------|

## 25.3. TS Register Description

### 25.3.1. TSC Control Register

|              |            |         |                                                                                                                                                      |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: TSC_CTRLR<br>Default Value: 0x0000_0000                                                                                               |
| Bit          | Read/Write | Default | Description                                                                                                                                          |
| 31:2         | /          | /       | /                                                                                                                                                    |
| 1            | R/W        | 0       | TSC Soft Reset<br>A software writing '1' will initiate a reset to all logic of TSC. And this bit will be cleared automatically after reset finishes. |
| 0            | R/W        | 0       | TSC Enable<br>0 – Disable<br>1 – Enable                                                                                                              |

### 25.3.2. TSC Status Register

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0x04 |            |         | Register Name: TSC_STAR<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                           |
| 31:0         | /          | /       | /                                                     |

### 25.3.3. TSC Port Control Register

|              |            |         |                                                         |
|--------------|------------|---------|---------------------------------------------------------|
| Offset: 0x10 |            |         | Register Name: TSC_PCTRLR<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                             |
| 31:1         | /          | /       | /                                                       |
| 0            | R/W        | 0       | TS Input Port0 Control<br>0 – SPI<br>1 – SSI            |

### 25.3.4. TSC Port Parameter Register

| Offset: 0x14 |                                                                                    |         | Register Name: TSC_PPARR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                           |     |            |     |          |   |                                                                                    |
|--------------|------------------------------------------------------------------------------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|-----|----------|---|------------------------------------------------------------------------------------|
| Bit          | Read/Write                                                                         | Default | Description                                                                                                                                                                                                                                                                                                                      |     |            |     |          |   |                                                                                    |
| 31:8         | /                                                                                  | /       | /                                                                                                                                                                                                                                                                                                                                |     |            |     |          |   |                                                                                    |
| 7:0          | R/W                                                                                | 0x00    | TS Input Port0 Parameters <table border="1" data-bbox="679 1763 1505 1980"> <thead> <tr> <th>Bit</th> <th>Definition</th> </tr> </thead> <tbody> <tr> <td>7:5</td> <td>Reserved</td> </tr> <tr> <td>4</td> <td>SSI data order<br/>0: MSB first for one byte data<br/>1: LSB first for one byte data</td> </tr> </tbody> </table> | Bit | Definition | 7:5 | Reserved | 4 | SSI data order<br>0: MSB first for one byte data<br>1: LSB first for one byte data |
| Bit          | Definition                                                                         |         |                                                                                                                                                                                                                                                                                                                                  |     |            |     |          |   |                                                                                    |
| 7:5          | Reserved                                                                           |         |                                                                                                                                                                                                                                                                                                                                  |     |            |     |          |   |                                                                                    |
| 4            | SSI data order<br>0: MSB first for one byte data<br>1: LSB first for one byte data |         |                                                                                                                                                                                                                                                                                                                                  |     |            |     |          |   |                                                                                    |

|  |  |  |   |                                                                            |
|--|--|--|---|----------------------------------------------------------------------------|
|  |  |  | 3 | CLOCK signal polarity<br>0 : Rise edge capturing<br>1: Fall edge capturing |
|  |  |  | 2 | ERROR signal polarity<br>0: High level active<br>1: Low level active       |
|  |  |  | 1 | DVALID signal polarity<br>0: High level active<br>1: Low level active      |
|  |  |  | 0 | PSYNC signal polarity<br>0: High level active<br>1: Low level active       |

### 25.3.5. TSC TSF Input Multiplex Control Register

| Offset: 0x20 |            |         | Register Name: TSC_TSFMUXR<br>Default Value: 0x0000_0000                                              |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                           |
| 31:4         | /          | /       | /                                                                                                     |
| 3:0          | R/W        | 0x0     | TSF0 Input Multiplex Control<br>0x0 –Data from TSG<br>0x1 –Data from TS IN Port0<br>Others – Reserved |

### 25.3.6. TSC Port Output Multiplex Control Register

| Offset: 0x28 |            |         | Register Name: TSC_TSFMUXR<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|----------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                              |
| 31:0         | /          | /       | /                                                        |

### 25.3.7. TSG Control and Status Register

| Offset: TSG+0x00 |            |         | Register Name: TSG_CSR<br>Default Value: 0x0000_0000                           |
|------------------|------------|---------|--------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                    |
| 31:26            | /          | /       | /                                                                              |
|                  |            |         | Status for TS Generator<br>0: IDLE state<br>1: Running state<br>2: PAUSE state |
| 25:24            | R          | 0       | Others: Reserved                                                               |
| 23:10            | /          | /       | /                                                                              |
| 9                | R/W        | 0       | Loop Buffer Mode<br>When set to '1', the TSG external buffer is in loop mode.  |

|     |     |   |                                                                                                                                                                                                                                                                                           |
|-----|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8   | R/W | 0 | Sync Byte Check Enable<br>Enable/ Disable check SYNC byte fro receiving new packet<br>0: Disable<br>1: Enable<br>If enable check SYNC byte and an error SYNC byte is received, TS Generator will come into PAUSE state. If the correspond interrupt is enabled, the interrupt will occur. |
| 7:3 | /   | / | /                                                                                                                                                                                                                                                                                         |
| 2   | R/W | 0 | Pause Bit for TS Generator<br>Write '1' to pause TS Generator. TS Generator will stop fetch new data from DRAM. After finishing this operation, this bit will be cleared to zero by hardware. In PAUSE state, write '1' to resume this state.                                             |
| 1   | R/W | 0 | Stop Bit for TS Generator<br>Write '1' to stop TS Generator. TS Generator will stop fetch new data from DRAM. The data already in its FIFO should be sent to TS filter. After finishing this operation, this bit will be cleared to zero by hardware.                                     |
| 0   | R/W | 0 | Start Bit for TS Generator<br>Write '1' to start TS Generator. TS Generator will fetch data from DRAM and generate SPI stream to TS filter. This bit will be cleared to zero by hardware after TS Generator is enabled.                                                                   |

### 25.3.8. TSG Packet Parameter Register

|                  |            |         |                                                                                                                                |
|------------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| Offset: TSG+0x04 |            |         | Register Name: TSG_PPR<br>Default Value: 0x0000_0000                                                                           |
| Bit              | Read/Write | Default | Description                                                                                                                    |
| 31:24            | /          | /       | /                                                                                                                              |
| 23:16            | R/W        | 0x47    | Sync Byte Value<br>This is the value of sync byte used in the TS Packet.                                                       |
| 15:8             | /          | /       | /                                                                                                                              |
| 7                | R/W        | 0       | Sync Byte Position<br>0: the 1st byte position<br>1: the 5th byte position<br>This bit is only used for 192 bytes packet size. |
| 6:2              | /          | /       | /                                                                                                                              |
| 1:0              | R/W        | 0       | Packet Size<br>Byte Size for one TS packet<br>0: 188 bytes<br>1: 192 bytes<br>2: 204 bytes<br>3: Reserved                      |

### 25.3.9. TSG Interrupt Enable and Status Register

| Offset: TSG+0x08 |            |         | Register Name: TSG_IESR<br>Default Value: 0x0000_0000                                                                                                                               |
|------------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                         |
| 31:20            | /          | /       | /                                                                                                                                                                                   |
| 19               | R/W        | 0       | TS Generator (TSG) End Interrupt Enable<br>0: Disable<br>1: Enable<br>When set this bit, the interrupt will assert to CPU when all data in external DRAM are sent to TS PID filter. |
| 18               | R/W        | 0       | TS Generator (TSG) Full Finish Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                          |
| 17               | R/W        | 0       | TS Generator (TSG) Half Finish Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                          |
| 16               | R/W        | 0       | TS Generator (TSG) Error Sync Byte Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                      |
| 15:4             | /          | /       | /                                                                                                                                                                                   |
| 3                | R/W        | 0       | TS Generator (TSG) End Status<br>Write '1' to clear.                                                                                                                                |
| 2                | R/W        | 0       | TS Generator (TSG) Full Finish Status<br>Write '1' to clear.                                                                                                                        |
| 1                | R/W        | 0       | TS Generator (TSG) Half Finish Status<br>Write '1' to clear.                                                                                                                        |
| 0                | R/W        | 0       | TS Generator (TSG) Error Sync Byte Status<br>Write '1' to clear.                                                                                                                    |

### 25.3.10. TSG Clock Control Register

| Offset: TSG+0x0c |            |         | Register Name: TSG_CCR<br>Default Value: 0x0000_0000                                                                                                                                                                            |
|------------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                     |
| 31:16            | R/W        | 0x0     | TSG Clock Divide Factor (N)<br>The Numerator part of TSG Clock Divisor Factor.                                                                                                                                                  |
| 15:0             | R/W        | 0x0     | TSG Clock Divide Factor (D)<br>The Denominator part of TSG Clock Divisor Factor.<br>Frequency of output clock:<br>$F_o = (F_i * (N+1)) / (8 * (D+1))$ .<br>Fi is the input special clock of TSC, and D must not be less than N. |

### 25.3.11. TSG Buffer Base Address Register

|                  |                         |
|------------------|-------------------------|
| Offset: TSG+0x10 | Register Name: TSG_BBAR |
|------------------|-------------------------|

|       |            |         |                                                                                                                                                                              |
|-------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |         | Default Value: 0x0000_0000                                                                                                                                                   |
| Bit   | Read/Write | Default | Description                                                                                                                                                                  |
| 31:28 | /          | /       | /                                                                                                                                                                            |
| 27:0  | RW         | 0x0     | Buffer Base Address<br>This value is a start address of TSG buffer.<br>Note: This value should be 4-word (16Bytes) align, and the lowest 4-bit of this value should be zero. |

### 25.3.12. TSG Buffer Size Register

|                  |            |         |                                                                                                                                              |
|------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: TSG+0x14 |            |         | Register Name: TSG_BSZR<br>Default Value: 0x0000_0000                                                                                        |
| Bit              | Read/Write | Default | Description                                                                                                                                  |
| 31:24            | /          | /       | /                                                                                                                                            |
| 23:0             | R/W        | 0       | Data Buffer Size for TS Generator<br>It is in byte unit.<br>The size should be 4-word (16Bytes) align, and the lowest 4 bits should be zero. |

### 25.3.13. TSG Buffer Pointer Register

|                  |            |         |                                                                                                      |
|------------------|------------|---------|------------------------------------------------------------------------------------------------------|
| Offset: TSG+0x18 |            |         | Register Name: TSG_BPR<br>Default Value: 0x1fff_0000                                                 |
| Bit              | Read/Write | Default | Description                                                                                          |
| 31:24            | /          | /       | /                                                                                                    |
| 23:0             | R          | 0       | Data Buffer Pointer for TS Generator<br>Current TS generator data buffer read pointer (in byte unit) |

### 25.3.14. TSF Control and Status Register

|                  |            |         |                                                                                                                                                                                            |
|------------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: TSF+0x00 |            |         | Register Name: TSF_CSR<br>Default Value: 0x0000_0000                                                                                                                                       |
| Bit              | Read/Write | Default | Description                                                                                                                                                                                |
| 31:1             | /          | /       | /                                                                                                                                                                                          |
| 0                |            |         | TSF Global Soft Reset<br>A software writing '1' will reset all status and state machine of TSF.<br>And it's cleared by hardware after reset ends.<br>A software writing '0' has no effect. |

### 25.3.15. TSF Packet Parameter Register

|                  |            |         |                                                                                                   |
|------------------|------------|---------|---------------------------------------------------------------------------------------------------|
| Offset: TSF+0x04 |            |         | Register Name: TSF_PPR<br>Default Value: 0x0000_0000                                              |
| Bit              | Read/Write | Default | Description                                                                                       |
| 31:28            | R/W        | 0       | Lost Sync Packet Threshold<br>It is used for packet sync lost by checking the value of sync byte. |

|       |     |      |                                                                                                                                      |
|-------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------|
| 27:24 | R/W | 0    | Sync Packet Threshold<br>It is used for packet sync by checking the value of sync byte.                                              |
| 23:16 | R/W | 0x47 | Sync Byte Value<br>This is the value of sync byte used in the TS Packet.                                                             |
| 15:10 | /   | /    | /                                                                                                                                    |
| 9:8   | R/W | 0    | Packet Sync Method<br>0: By PSYNC signal<br>1: By sync byte<br>2: By both PSYNC and Sync Byte<br>3: Reserved                         |
| 7     | R/W | 0    | Sync Byte Position<br>0: the 1st byte position<br>1: the 5th byte position<br>Note: This bit is only used for 192 bytes packet size. |
| 6:2   | /   | /    | /                                                                                                                                    |
| 1:0   | R/W | 0    | Packet Size<br>Byte Size for one TS packet<br>0: 188 bytes<br>1: 192 bytes<br>2: 204 bytes<br>3: Reserved                            |

### 25.3.16. TSF Interrupt Enable and Status Register

| Offset: TSF+0x08 |            |         | Register Name: TSF_IESR<br>Default Value: 0x0000_0000                                  |
|------------------|------------|---------|----------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                            |
| 31:20            | /          | /       | /                                                                                      |
| 19               | R/W        | 0       | TS PID Filter (TSF) Internal FIFO Overrun Interrupt Enable<br>0: Disable<br>1: Enable  |
| 18               | R/W        | 0       | TS PCR Packet Detect Interrupt Enable<br>0: Disable<br>1: Enable                       |
| 17               | R/W        | 0       | TS PID Filter (TSF) Channel Overlap Interrupt Global Enable<br>0: Disable<br>1: Enable |
| 16               | R/W        | 0       | TS PID Filter (TSF) Channel DMA Interrupt Global Enable<br>0: Disable<br>1: Enable     |
| 15:4             | /          | /       | /                                                                                      |
| 3                | R/W        | 0       | TS PID Filter (TSF) Internal FIFO Overrun Status<br>Write '1' to clear.                |
| 2                | R/W        | 0       | TS PCR Packet Found Status                                                             |

|   |   |   |                                                                                                                                                          |
|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |   |   | When it is ‘1’, one TS PCR Packet is found. Write ‘1’ to clear.                                                                                          |
| 1 | R | 0 | TS PID Filter (TSF) Channel Overlap Status<br>It is global status for 16 channel. It will be cleared to zero after all channels status bits are cleared. |
| 0 | R | 0 | TS PID Filter (TSF) Channel DMA status<br>It is global status for 16 channel. It will be cleared to zero after all channels status bits are cleared.     |

### 25.3.17. TSF DMA Interrupt Enable Register

|                  |            |         |                                                                     |
|------------------|------------|---------|---------------------------------------------------------------------|
| Offset: TSF+0x10 |            |         | Register Name: TSF_DIER<br>Default Value: 0x0000_0000               |
| Bit              | Read/Write | Default | Description                                                         |
| 31:0             | R/W        | 0x0     | DMA Interrupt Enable<br>DMA interrupt enable bits for channel 0~31. |

### 25.3.18. TSF Overlap Interrupt Enable Register

|                  |            |         |                                                                             |
|------------------|------------|---------|-----------------------------------------------------------------------------|
| Offset: TSF+0x14 |            |         | Register Name: TSF_OIER<br>Default Value: 0x0000_0000                       |
| Bit              | Read/Write | Default | Description                                                                 |
| 31:0             | R/W        | 0x0     | Overlap Interrupt Enable<br>Overlap interrupt enable bits for channel 0~31. |

### 25.3.19. TSF DMA Interrupt Status Register

|                  |            |         |                                                                                                                                                                                                                                               |
|------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: TSF+0x18 |            |         | Register Name: TSF_DISR<br>Default Value: 0x3FFF_0000                                                                                                                                                                                         |
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                                   |
| 31:0             | R/W        | 0x0     | DMA Interrupt Status<br>DMA interrupt Status bits for channel 0~31.<br>Set by hardware, and can be cleared by software writing ‘1’.<br>When these bits and the corresponding DMA Interrupt Enable bits are set, the TSF interrupt will occur. |

### 25.3.20. TSF Overlap Interrupt Status Register

|                  |            |         |                                                                                                                                                                                                                                                           |
|------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: TSF+0x1c |            |         | Register Name: TSF_OISR<br>Default Value: 0x0000_0000                                                                                                                                                                                                     |
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                                               |
| 31:0             | R/W        | 0x0     | Overlap Interrupt Status<br>Overlap interrupt Status bits for channel 0~31.<br>Set by hardware, and can be cleared by software writing ‘1’.<br>When these bits and the corresponding Overlap Interrupt Enable bits are set, the TSF interrupt will occur. |

### 25.3.21. TSF PCR Control Register

| Offset: TSF+0x20 |            |         | Register Name: TSF_PCRCCR<br>Default Value: 0x0000_0000   |
|------------------|------------|---------|-----------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                               |
| 31:17            | /          | /       | /                                                         |
| 16               | R/W        | 0       | PCR Detecting Enable<br>0: Disable<br>1: Enable           |
| 15:13            | /          | /       | /                                                         |
| 12:8             | R/W        | 0       | Channel Index m for Detecting PCR packet (m from 0 to 31) |
| 7:1              | /          | /       | /                                                         |
| 0                | R          | 0       | PCR Contest LSB 1 bit<br>PCR[0]                           |

### 25.3.22. TSF PCR Data Register

| Offset: TSF+0x24 |            |         | Register Name: TSF_PCRDR<br>Default Value: 0x0000_0000 |
|------------------|------------|---------|--------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                            |
| 31:0             | R          | 0       | PCR Data High 32 bits<br>PCR[33:1]                     |

### 25.3.23. TSF Channel Enable Register

| Offset: TSF+0x30 |            |         | Register Name: TSF_CENR<br>Default Value: 0x0000_0000                                                                                                   |
|------------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                             |
| 31:0             | R/W        | 0x0     | Filter Enable for Channel 0~31<br>0: Disable<br>1: Enable<br>From Disable to Enable, internal status of the corresponding filter channel will be reset. |

### 25.3.24. TSF Channel PES Enable Register

| Offset: TSF+0x34 |            |         | Register Name: TSF_CPER<br>Default Value: 0x0000_0000                                                                                        |
|------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                  |
| 31:0             | R/W        | 0x0     | PES Packet Enable for Channel 0~31<br>0: Disable<br>1: Enable<br>These bits should not be changed when the corresponding channel is enabled. |

### 25.3.25. TSF Channel Descramble Enable Register

| Offset: TSF+0x38 |            |         | Register Name: TSF_CDER<br>Default Value: 0x0000_0000 |
|------------------|------------|---------|-------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                           |
| 31:0             | /          | /       | /                                                     |

### 25.3.26. TSF Channel Index Register

| Offset: TSF+0x3c |            |         | Register Name: TSF_CINDR<br>Default Value: 0x0000_0000                                                                                                                                        |
|------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                                   |
| 31:5             | /          | /       | /                                                                                                                                                                                             |
| 4:0              | R/W        | 0x0     | Channel Index<br><br>This value is the channel index for channel private registers access.<br><br>Range is from 0x00 to 0x1f.<br><br>Address range of channel private registers is 0x40~0x7f. |

### 25.3.27. TSF Channel Control Register

| Offset: TSF+0x40 |            |         | Register Name: TSF_CCTRLR<br>Default Value: 0x0000_0000 |
|------------------|------------|---------|---------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                             |
| 31:0             | /          | /       | /                                                       |

### 25.3.28. TSF Channel Status Register

| Offset: TSF+0x44 |            |         | Register Name: TSF_CSTAR<br>Default Value: 0x0000_0000 |
|------------------|------------|---------|--------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                            |
| 31:0             | /          | /       | /                                                      |

### 25.3.29. TSF Channel CW Index Register

| Offset: TSF+0x48 |            |         | Register Name: TSF_CCWIR<br>Default Value: 0x0000_0000 |
|------------------|------------|---------|--------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                            |
| 31:0             | /          | /       | /                                                      |

### 25.3.30. TSF Channel PID Register

| Offset: TSF+0x4c |            |         | Register Name: TSF_CPIDR<br>Default Value: 0x1ff_0000                             |
|------------------|------------|---------|-----------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                       |
| 31:16            | R/W        | 0x1ff   | Filter PID Mask for Channel                                                       |
| 15:0             | R/W        | 0x0     | Filter PID value for Channel<br><br>Filter Fit: Input PID & PID Mask == PID Value |

### 25.3.31. TSF Channel Buffer Base Address Register

| Offset: TSF+0x50 |            |         | Register Name: TSF_CBBAR<br>Default Value: 0x0000_0000                                                          |
|------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                     |
| 31:28            | /          | /       | /                                                                                                               |
| 27:0             | R/W        | 0       | Data Buffer Base Address for Channel<br>It is 4-word (16Bytes) align address. The LSB four bits should be zero. |

### 25.3.32. TSF Channel Buffer Size Register

| Offset: TSF+0x54 |            |         | Register Name: TSF_CBSZR<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:26            | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 25:24            | R/W        | 0       | DMA Interrupt Threshold for Channel m (m from 1 to 15)<br>The unit is TS packet size. When received packet (has also stored in DRAM) size is beyond ( $\geq$ ) threshold value, the corresponding channel interrupt is generated to CPU. TSC should count the new received packet again, and when it exceeds the specified threshold value, a new interrupt is generated.<br>0: 1/2 data buffer packet size<br>1: 1/4 data buffer packet size<br>2: 1/8 data buffer packet size<br>3: 1/16 data buffer packet size |
| 23:21            | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 20:0             | R/W        | 0       | Data Buffer Packet Size for Channel<br>The exact buffer size of buffer is N+1 bytes.<br>The maximum buffer size is 2MB.<br>This size should be 4-word (16Bytes) aligned. The LSB four bits should be zero.                                                                                                                                                                                                                                                                                                         |

### 25.3.33. TSF Channel Buffer Write Pointer Register

| Offset: TSF+0x58 |            |         | Register Name: TSF_CBWPR<br>Default Value: 0x0000_0000                                                                                                                                                                                                              |
|------------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                                                                                                                                                                                                         |
| 31:21            | /          | /       | /                                                                                                                                                                                                                                                                   |
| 20:0             | R/W        | 0       | Data Buffer Write Pointer (in Bytes)<br>This value is changed by hardware, when data is filled into buffer, this pointer increases.<br>And this pointer can be set by software, but it should not be changed by software when the corresponding channel is enabled. |

#### **25.3.34. TSF Channel Buffer Read Pointer Register**

| Offset: TSF+0x5c |            |         | Register Name: TSF_CBRPR<br>Default Value: 0x0000_0000                       |
|------------------|------------|---------|------------------------------------------------------------------------------|
| Bit              | Read/Write | Default | Description                                                                  |
| 31:21            | /          | /       | /                                                                            |
|                  |            |         | Data Buffer Read Pointer (in Bytes)                                          |
| 20:0             | R/W        | 0       | This pointer should be changed by software after the data of buffer is read. |

### **25.4. TS Clock Requirement**

| Clock Name | Description                    | Requirement        |
|------------|--------------------------------|--------------------|
| HCLK       | AHB bus clock                  |                    |
| TS_CLK     | Clock of TS Stream in SPI mode |                    |
| TSC_CLK    | TS serial clock from CCU       | TSC_CLK >=8*TS_CLK |

# 26. Audio Codec

## 26.1. Overview

The embedded Audio Codec is a high-quality stereo audio codec with headphone amplifier, which features

- On-chip 24-bits DAC for play-back
- On-chip 24-bits ADC for recorder
- Support analog/ digital volume control
- Support 48K and 44.1K sample family
- DAC supports 192K and 96K sample
- Support FM/ Line-in/ Microphone recorder
- Stereo headphone amplifier that can be operated in capless headphone mode
- Support Virtual Ground to automatically change to True Ground to protect headphone amplifier and make function work in normal mode

## 26.2. Audio Codec Block Diagram



Figure 26-1 Audio Codec Block Diagram

## 26.3. Audio Codec Register List

| Module Name | Base Address |
|-------------|--------------|
|-------------|--------------|

|    |            |
|----|------------|
| AC | 0x01C22C00 |
|----|------------|

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| AC_DAC_DPC    | 0x00   | DAC Digital Part Control Register |
| AC_DAC_FIFOC  | 0x04   | DAC FIFO Control Register         |
| AC_DAC_FIFOS  | 0x08   | DAC FIFO Status Register          |
| AC_DAC_TXDATA | 0x0C   | DAC TX Data Register              |
| AC_DAC_ACTL   | 0x10   | DAC Analog Control Register       |
| AC_ADC_FIFOC  | 0x1C   | ADC FIFO Control Register         |
| AC_ADC_FIFOS  | 0x20   | ADC FIFO Status Register          |
| AC_ADC_RXDATA | 0x24   | ADC RX Data Register              |
| AC_ADC_ACTL   | 0x28   | ADC Analog Control Register       |
| AC_DAC_CNT    | 0x30   | DAC TX FIFO Counter Register      |
| AC_ADC_CNT    | 0x34   | ADC RX FIFO Counter Register      |

## 26.4. Audio Codec Register Description

### 26.4.1. DAC Digital Part Control Register

| Offset: 0x00 |            |         | Register Name: AC_DAC_DPC                                    |
|--------------|------------|---------|--------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                  |
| 31           | R/W        | 0x0     | EN_DA.<br>DAC Digital Part Enable<br>0: Disable<br>1: Enable |
| 30:29        | /          | /       | /                                                            |
| 28:25        | /          | /       | /                                                            |
| 24           | /          | /       | /                                                            |
| 23:19        | /          | /       | /                                                            |
| 18           | /          | /       | /                                                            |
| 17:12        | /          | /       | /                                                            |
| 11:0         | /          | /       | /                                                            |

### 26.4.2. DAC FIFO Control Register

| Offset: 0x4 |            |         | Register Name: AC_DAC_FIFOC                                                            |
|-------------|------------|---------|----------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                            |
| 31:29       | R/W        | 0x0     | DAC_FS.<br>Sample Rate of DAC<br>000: 48KHz<br>010: 24KHz<br>100: 12KHz<br>110: 192KHz |



|   |     |     |                                                                                   |
|---|-----|-----|-----------------------------------------------------------------------------------|
|   |     |     | Transmitting Audio Sample Resolution<br>0: 16 bits<br>1: 24 bits                  |
| 4 | R/W | 0x0 | DAC_DRQ_EN.<br>DAC FIFO Empty DRQ Enable<br>0: Disable<br>1: Enable               |
| 3 | R/W | 0x0 | DAC_IRQ_EN.<br>DAC FIFO Empty IRQ Enable<br>0: Disable<br>1: Enable               |
| 2 | R/W | 0x0 | FIFO_UNDERRUN_IRQ_EN.<br>DAC FIFO Under Run IRQ Enable<br>0: Disable<br>1: Enable |
| 1 | R/W | 0x0 | FIFO_OVERRUN_IRQ_EN.<br>DAC FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable   |
| 0 | R/W | 0x0 | FIFO_FLUSH.<br>DAC FIFO Flush<br>Write '1' to flush TX FIFO, self clear to '0'    |

#### 26.4.3. DAC FIFO Status Register

| Offset: 0x8 |            |         | Register Name: AC_DAC_FIFOS                                                                                                                                                               |
|-------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | 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 (>= 1 word)                                                         |
| 22:8        | R          | 0x80    | TXE_CNT.<br>TX FIFO Empty Space Word Counter                                                                                                                                              |
| 7:4         | /          | /       | /                                                                                                                                                                                         |
| 3           | R/W        | 0x1     | TXE_INT.<br>TX FIFO Empty Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Empty Pending Interrupt<br>Write '1' to clear this interrupt or automatic clear if interrupt condition fails. |
| 2           | R/W        | 0x0     | TXU_INT.<br>TX FIFO Under run Pending Interrupt                                                                                                                                           |

|   |     |     |                                                                                                                                                    |
|---|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------|
|   |     |     | 0: No Pending Interrupt<br>1: FIFO Under run Pending Interrupt<br>Write '1' to clear this interrupt                                                |
| 1 | R/W | 0x0 | TXO_INT.<br>TX FIFO Overrun Pending Interrupt<br>0: No Pending Interrupt<br>1: FIFO Overrun Pending Interrupt<br>Write '1' to clear this interrupt |
| 0 | /   | /   | /                                                                                                                                                  |

#### 26.4.4. DAC TX DATA Register

| Offset: 0xC |            |         | Register Name: AC_DAC_TXDATA                                                                                                                                                  |
|-------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/Write | Default | Description                                                                                                                                                                   |
| 31:0        | W          | 0x0     | TX_DATA.<br>Transmitting left, right channel sample data should be written this register one by one. The left channel sample data is first and then the right channel sample. |

#### 26.4.5. DAC Analog Control Register

| Offset:0x10 |     |         | Register Name: AC_DAC_ACTRL                                                                     |
|-------------|-----|---------|-------------------------------------------------------------------------------------------------|
| Bit         | R/W | Default | Description                                                                                     |
| 31          | R/W | 0x0     | DACAREN.<br>Internal DAC Analog Right channel Enable<br>0:Disable<br>1:Enable                   |
| 30          | R/W | 0x0     | DACALEN.<br>Internal DAC Analog Left channel Enable<br>0:Disable<br>1:Enable                    |
| 29          | R/W | 0x0     | MIXEN.<br>Analog Output Mixer Enable<br>0:Disable<br>1:Enable                                   |
| 28:27       | /   | /       | /                                                                                               |
| 26          | R/W | 0x1     | LNG.<br>Line-in gain stage to output mixer Gain Control<br>0: -1.5dB<br>1: 0dB                  |
| 25:23       | R/W | 0x3     | FMG.<br>FM Input to output mixer Gain Control<br>From -4.5dB to 6dB, 1.5dB/step, default is 0dB |
| 22:20       | R/W | 0x3     | MICG.                                                                                           |

|    |     |     |                                                                                                                                                                             |
|----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |     |     | MIC1/2 gain stage to output mixer Gain Control<br>From -4.5dB to 6dB, 1.5dB/step, default is 0dB                                                                            |
| 19 | R/W | 0x0 | LLNS.<br>Left LINEIN gain stage to left output mixer mute<br>0-mute; 1-Not mute<br>When LNRDF is 0, left select LINEINL<br>When LNRDF is 1, left select LINEINL-LINEINR     |
| 18 | R/W | 0x0 | RLNS.<br>Right LINEIN gain stage to right output mixer mute<br>0-mute; 1-Not mute<br>When LNRDF is 0, right select LINEINR<br>When LNRDF is 1, right select LINEINL-LINEINR |
| 17 | R/W | 0x0 | LFMS.<br>Left FM to left output mixer mute<br>0:mute<br>1:Not mute                                                                                                          |
| 16 | R/W | 0x0 | RFMS.<br>right FM to right output mixer mute<br>0:mute<br>1:Not mute                                                                                                        |
| 15 | R/W | 0x0 | LDACLMIXS.<br>Left DAC to left output mixer Mute<br>0:Mute<br>1:Not mute                                                                                                    |
| 14 | R/W | 0x0 | RDACRMIXS.<br>Right DAC to right output mixer Mute<br>0:Mute<br>1:Not mute                                                                                                  |
| 13 | R/W | 0x0 | LDACRMIXS.<br>Left DAC to right output mixer Mute,<br>0:Mute<br>1:Not mute                                                                                                  |
| 12 | R/W | 0x0 | MIC1LS.<br>MIC1 to output mixer left channel mute<br>0: mute<br>1: Not mute                                                                                                 |
| 11 | R/W | 0x0 | MIC1RS.<br>MIC1 to output mixer right channel mute<br>0: mute<br>1: Not mute                                                                                                |
| 10 | R/W | 0x0 | MIC2LS.<br>MIC2 to output mixer left channel mute<br>0: mute                                                                                                                |

|     |     |     |                                                                                                               |
|-----|-----|-----|---------------------------------------------------------------------------------------------------------------|
|     |     |     | 1: Not mute                                                                                                   |
| 9   | R/W | 0x0 | MIC2RS.<br>MIC2 to output mixer right channel mute<br>0: mute<br>1: Not mute                                  |
| 8   | R/W | 0x0 | DACPAS.<br>DAC to PA Mute<br>0-Mute<br>1-Not mute                                                             |
| 7   | R/W | 0x0 | MIXPAS.<br>Output Mixer to PA mute<br>0: Mute<br>1: Not mute                                                  |
| 6   | R/W | 0x0 | PAMUTE.<br>All input source to PA mute, including Output mixer and Internal DAC,<br>(): 0:Mute<br>1: Not mute |
| 5:0 | R/W | 0x0 | PAVOL.<br>PA Volume Control, (PAVOL): Total 64 level, from 0dB to -62dB,<br>1dB/step, mute when 000000        |

#### 26.4.6. ADC FIFO Control Register

| Offset: 0x1C |            |         | Register Name: AC_ADC_FIFOC                                                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                      |
| 31:29        | R/W        | 0x0     | ADFS.<br>Sample Rate of ADC<br>000: 48KHz<br>010: 24KHz<br>100: 12KHz<br>110: Reserved<br>001: 32KHz<br>011: 16KHz<br>101: 8KHz<br>111: Reserved |
| 28           | R/W        | 0x0     | EN_AD.<br>ADC Digital Part Enable, en_ad<br>0: Disable<br>1: Enable                                                                              |
| 27:25        | /          | /       | /                                                                                                                                                |
| 24           | R/W        | 0x0     | RX_FIFO_MODE.<br>RX FIFO Output Mode (Mode 0, 1)<br>0: Expanding '0' at LSB of TX FIFO register                                                  |

|       |     |     |                                                                                                                                                                                                                                                                                                                          |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1: Expanding received sample sign bit at MSB of TX FIFO register<br>For 24-bits received audio sample:<br>Mode 0: RXDATA[31:0] = {FIFO_O[23:0], 8'h0}<br>Mode 1: Reserved<br>For 16-bits received audio sample:<br>Mode 0: RXDATA[31:0] = {FIFO_O[23:8], 16'h0}<br>Mode 1: RXDATA[31:0] = {16{FIFO_O[23]}, FIFO_O[23:8]} |
| 23:13 | /   | /   | /                                                                                                                                                                                                                                                                                                                        |
| 12:8  | R/W | 0xF | RX_FIFO_TRG_LEVEL.<br>RX FIFO Trigger Level (RXTL[4:0])<br>Interrupt and DMA request trigger level for TX FIFO normal condition<br>IRQ/DRQ Generated when WLEVEL > RXTL[4:0]<br>Note:<br>WLEVEL represents the number of valid samples in the RX FIFO                                                                    |
| 7     | R/W | 0x0 | ADC_MONO_EN.<br>ADC Mono Enable.<br>0: Stereo, 16 levels FIFO<br>1: mono, 32 levels FIFO<br>When set to '1', Only left channel samples are recorded                                                                                                                                                                      |
| 6     | R/W | 0x0 | RX_SAMPLE_BITS.<br>Receiving Audio Sample Resolution<br>0: 16 bits<br>1: 24 bits                                                                                                                                                                                                                                         |
| 5     | /   | /   | /                                                                                                                                                                                                                                                                                                                        |
| 4     | R/W | 0x0 | ADC_DRQ_EN.<br>ADC FIFO Data Available DRQ Enable.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                            |
| 3     | R/W | 0x0 | ADC_IRQ_EN.<br>ADC FIFO Data Available IRQ Enable.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                            |
| 2     | /   | /   | /                                                                                                                                                                                                                                                                                                                        |
| 1     | R/W | 0x0 | ADC_OVERRUN_IRQ_EN.<br>ADC FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                           |
| 0     | R/W | 0x0 | ADC_FIFO_FLUSH.<br>ADC FIFO Flush.<br>Write '1' to flush TX FIFO, self clear to '0'.                                                                                                                                                                                                                                     |

#### 26.4.7. ADC FIFO Status Register

| Offset: 0x20 |            |         | Register Name: AC_ADC_FIFOS                                                                                                                                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | 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:14        | /          | /       | /                                                                                                                                                                                                |
| 13:8         | R          | 0x0     | RXA_CNT.<br>RX FIFO Available Sample Word Counter                                                                                                                                                |
| 7:4          | /          | /       | /                                                                                                                                                                                                |
| 3            | R/W        | 0x0     | RXA_INT.<br>RX FIFO Data Available Pending Interrupt<br>0: No Pending IRQ<br>1: Data Available Pending IRQ<br>Write '1' to clear this interrupt or automatic clear if interrupt condition fails. |
| 2            | /          | /       | /                                                                                                                                                                                                |
| 1            | R/W        | 0x0     | RXO_INT.<br>RX FIFO Overrun Pending Interrupt<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt                                                           |
| 0            | /          | /       | /                                                                                                                                                                                                |

#### 26.4.8. ADC RX DATA Register

| Offset: 0x24 |            |         | Register Name: AC_ADC_RXDATA<br>Default Value: 0x0000_0000                                                                                          |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                         |
| 31:0         | R          | 0x0     | RX_DATA.<br>RX Sample<br>Host can get one sample by reading this register. The left channel sample data is first and then the right channel sample. |

#### 26.4.9. ADC Analog Control Register

| Offset: 0x28 |     |         | Register Name: AC_PA_ADC_ACTRL                   |
|--------------|-----|---------|--------------------------------------------------|
| Bit          | R/W | Default | Description                                      |
| 31           | R/W | 0x0     | ADCREN.<br>ADC Right Channel Enable<br>0-Disable |

|       |     |     |                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 1-Enable                                                                                                                                          |
| 30    | R/W | 0x0 | ADCLEN.<br>ADC Left Channel Enable<br>0-Disable<br>1-Enable                                                                                       |
| 29    | R/W | 0x0 | PREG1EN.<br>MIC1 pre-amplifier Enable<br>0-Disable<br>1-Enable                                                                                    |
| 28    | R/W | 0x0 | PREG2EN.<br>MIC2 pre-amplifier Enable<br>0-Disable<br>1-Enable                                                                                    |
| 27    | R/W | 0x0 | VMICEN.<br>VMIC pin voltage enable<br>0: disable<br>1: enable                                                                                     |
| 26:25 | R/W | 0x2 | PREG1.<br>MIC1 pre-amplifier Gain Control<br>00: 0dB<br>01: 35dB<br>10: 38dB<br>11: 41dB                                                          |
| 24:23 | R/W | 0x2 | PREG2.<br>MIC2 pre-amplifier Gain Control<br>00: 0dB<br>01: 35dB<br>10: 38dB<br>11: 41dB                                                          |
| 22:20 | R/W | 0x3 | ADCG.<br>ADC Input Gain Control<br>000: -4.5dB<br>001: -3dB<br>010: -1.5dB<br>011: 0dB<br>100: 1.5dB<br>101: 3dB<br>110: 4.5dB<br>111: 6dB        |
| 19:17 | R/W | 0x2 | ADCIS.<br>ADC input source select<br>000: left select LINEINL, right select LINEINR; or, both select LINEINL-LINEINR, depending on LNRDF (bit 16) |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 001: left channel select FMINL & right channel select FMINR<br>010: left and right channel both select MIC1 gain stage output<br>011: left and right channel both select MIC2 gain stage output<br>100: left select MIC1 gain stage output & right select MIC2 gain stage output<br>101: left and right both select MIC1 gain stage plus MIC2 gain stage output<br>110: left select output mixer L & right select output Mixer right<br>111: left select LINEINL or LINEINL-LINEINR, depending on LNRDF (bit 16), right select MIC1 gain stage |
| 16    | R/W | 0x0 | LNRDF.<br>Line-in-r function define<br>0: Line-in right channel which is independent of line-in left channel<br>1: negative input of line-in left channel for fully differential application                                                                                                                                                                                                                                                                                                                                                   |
| 15:13 | R/W | 0x4 | LNPREG.<br>Line-in pre-amplifier Gain Control<br>From -12dB to 9dB, 3dB/step, default is 0dB                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12    | R/W | 0x0 | MIC1NEN.<br>Mic1outn enable<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11:9  | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 8     | R/W | 0x1 | DITHER.<br>ADC dither on/off control<br>0: dither off<br>1: dither on                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:6   | R/W | 0x1 | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5     | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4     | R/W | 0x0 | PA_EN.<br>PA Enable<br>0-disable<br>1-enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3     | R/W | 0x1 | DDE.<br>Headphone direct-drive enable, (DDE):<br>0-disable<br>1-enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2     | R/W | 0x1 | COMPSEN.<br>HPCOM output protection enable<br>0: protection disable<br>1: protection enable                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1:0   | R/W | 0x0 | PTDBS.<br>HPCOM protect de-bounce time setting<br>00: 2-3ms                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|  |  |  |                                        |
|--|--|--|----------------------------------------|
|  |  |  | 01: 4-6ms<br>10: 8-12ms<br>11: 16-24ms |
|--|--|--|----------------------------------------|

#### 26.4.10. DAC TX Counter Register

| Offset: 0x30 |            |         | Register Name: AC_DAC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:0         | R/W        | 0x0     | <p>TX_CNT.<br/>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 been updated by the initial value, the counter register should count on base of this initial value.</p> <p>Notes: It is used for Audio/ Video Synchronization</p> |

#### 26.4.11. ADC RX Counter Register

| Offset: 0x34 |            |         | Register Name: AC_ADC_CNT                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | 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 been updated by the initial value, the counter register should count on base of this initial value.</p> <p>Notes: It is used for Audio/ Video Synchronization</p> |

# 27. LRADC

## 27.1. Overview

The LRADC is 6-bits resolution, and can work up to maximum conversion rate of 250Hz.

It features:

- Support APB 32-bit bus width
- Support interrupt
- Support Hold Key and General Key
- Support Single Key and continue key mode
- 6-bits Resolution
- Voltage input range between 0 to 2V
- Sample Rate up to 250Hz

## 27.2. Principle of operation

### 27.2.1. Block Diagram

The LRADC converted data can be accessed by interrupt and polling method. If software can't access the last converted data instantly, the new converted data would update the old one at new sampling data.

### 27.2.2. Hold Key and General Key Function Introduction

When ADC\_IN Signal change from 3V to 2V (Level A), the comparator24 send first interrupt to control logic; When ADC\_IN Signal changes from 2V to certain level (Program can set), the comparator25 give second interrupt. If the control Logic get the first interrupt, In a certain time range (program can set), doesn't get second interrupt, it will send hold key interrupt to the host; If the control Logic get the first interrupt, In a certain time range (program can set), get second interrupt, it will send key down interrupt to the host; If the control logic only get the second interrupt, doesn't get the first interrupt, it will send already hold interrupt to the host.



## 27.3. LRADC Register Description

### 27.3.1. LRADC Control Register

| Offset: 0x04 |                |                 | Register Name: LRADC_INTC                                                               |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex | Description                                                                             |
| 31:16        | /              | /               | /                                                                                       |
| 12           | R/W            | 0x0             | ADC1_KEYUP_IRQ_EN.<br>ADC 1 Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 11           | R/W            | 0x0             | ADC1_ALRDY_HOLD_IRQ_EN.<br>ADC 1 Already Hold Key IRQ Enable<br>0: Disable<br>1: Enable |
| 10           | R/W            | 0x0             | ADC 1 Hold Key IRQ Enable<br>0: Disable<br>1: Enable                                    |
| 9            | R/W            | 0x0             | ADC1_KEYIRQ_EN.<br>ADC 1 Key IRQ Enable<br>0: Disable<br>1: Enable                      |
| 8            | R/W            | 0x0             | ADC1_DATA_IRQ_EN.<br>ADC 1 DATA IRQ Enable<br>0: Disable<br>1: Enable                   |
| 7:5          | /              | /               | /                                                                                       |
| 4            | R/W            | 0x0             | ADC0_KEYUP_IRQ_EN.<br>ADC 0 Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 3            | R/W            | 0x0             | ADC0_ALRDY_HOLD_IRQ_EN.<br>ADC 0 Already Hold IRQ Enable<br>0: Disable<br>1: Enable     |
| 2            | R/W            | 0x0             | ADC0_HOLD_IRQ_EN.<br>ADC 0 Hold Key IRQ Enable<br>0: Disable<br>1: Enable               |
| 1            | R/W            | 0x0             | ADC0_KEYDOWN_EN<br>ADC 0 Key Down Enable                                                |

|   |     |     |                                                                       |
|---|-----|-----|-----------------------------------------------------------------------|
|   |     |     | 0: Disable<br>1: Enable                                               |
| 0 | R/W | 0x0 | ADC0_DATA_IRQ_EN.<br>ADC 0 Data IRQ Enable<br>0: Disable<br>1: Enable |

### 27.3.2. LRADC Interrupt Control Register

| Offset: 0x04 |                |                 | Register Name: LRADC_INTC                                                               |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                             |
| 31:16        | /              | /               | /                                                                                       |
| 12           | R/W            | 0x0             | ADC1_KEYUP_IRQ_EN.<br>ADC 1 Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 11           | R/W            | 0x0             | ADC1_ALRDY_HOLD_IRQ_EN.<br>ADC 1 Already Hold Key IRQ Enable<br>0: Disable<br>1: Enable |
| 10           | R/W            | 0x0             | ADC 1 Hold Key IRQ Enable<br>0: Disable<br>1: Enable                                    |
| 9            | R/W            | 0x0             | ADC1_KEYIRQ_EN.<br>ADC 1 Key IRQ Enable<br>0: Disable<br>1: Enable                      |
| 8            | R/W            | 0x0             | ADC1_DATA_IRQ_EN.<br>ADC 1 DATA IRQ Enable<br>0: Disable<br>1: Enable                   |
| 7:5          | /              | /               | /                                                                                       |
| 4            | R/W            | 0x0             | ADC0_KEYUP_IRQ_EN.<br>ADC 0 Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 3            | R/W            | 0x0             | ADC0_ALRDY_HOLD_IRQ_EN.<br>ADC 0 Already Hold IRQ Enable<br>0: Disable<br>1: Enable     |
| 2            | R/W            | 0x0             | ADC0_HOLD_IRQ_EN.<br>ADC 0 Hold Key IRQ Enable                                          |

|   |     |     |                                                                       |
|---|-----|-----|-----------------------------------------------------------------------|
|   |     |     | 0: Disable<br>1: Enable                                               |
| 1 | R/W | 0x0 | ADC0_KEYDOWN_EN<br>ADC 0 Key Down Enable<br>0: Disable<br>1: Enable   |
| 0 | R/W | 0x0 | ADC0_DATA_IRQ_EN.<br>ADC 0 Data IRQ Enable<br>0: Disable<br>1: Enable |

### 27.3.3. LRADC Interrupt Status Register

| Offset: 0x08 |                |                 | Register Name: LRADC_INT                                                                                                                                                                                                                                                                                              |
|--------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                           |
| 31:8         | /              | /               | /                                                                                                                                                                                                                                                                                                                     |
| 12           |                | 0x0             | ADC1_KEYUP_PENDING.<br>ADC 1 Key up pending Bit<br>When general key pull up, if the corresponding interrupt is enabled.<br>0: No IRQ<br>1: IRQ Pending<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable                                                        |
| 11           | R/W            | 0x0             | ADC1_ALRDY_HOLD_PENDING.<br>ADC 1 Already Hold Pending Bit<br>When hold key pull down and pull the general key down, if the corresponding interrupt is enabled.<br>0: No IRQ<br>1: IRQ Pending<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable                |
| 10           | R/W            | 0x0             | ADC1_HOLDKEY_PENDING.<br>ADC 1 Hold Key pending Bit<br>When Hold key pull down, the status bit is set and the interrupt line is set if the corresponding interrupt is enabled.<br>0: NO IRQ<br>1: IRQ Pending<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable |
| 9            | R/W            | 0x0             | ADC1_KEYDOWN_IRQ_PENDING.<br>ADC 1 Key Down IRQ Pending Bit<br>When General key pull down, the status bit is set and the interrupt line                                                                                                                                                                               |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                     |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | <p>is set if the corresponding interrupt is enabled.</p> <p>0: No IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                                                                                                                                          |
| 8   | R/W | 0x0 | <p>ADC1_DATA_IRQ_PENDING.<br/>ADC 1 Data IRQ Pending Bit</p> <p>0: No IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled</p>                                                                                                                                       |
| 7:5 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                   |
| 4   | R/W | 0x0 | <p>ADC0_KEYUP_PENDING.<br/>ADC 0 Key up pending Bit</p> <p>When general key pull up, if the corresponding interrupt is enabled.</p> <p>0: No IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                                                               |
| 3   | R/W | 0x0 | <p>ADC0_ALRDY_HOLD_PENDING.<br/>ADC 0 Already Hold Pending Bit</p> <p>When hold key pull down and pull the general key down, if the corresponding interrupt is enabled.</p> <p>0: No IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                       |
| 2   | R/W | 0x0 | <p>ADC0_HOLDKEY_PENDING.<br/>ADC 0 Hold Key pending Bit</p> <p>When Hold key pull down, the status bit is set and the interrupt line is set if the corresponding interrupt is enabled.</p> <p>0: NO IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>        |
| 1   | R/W | 0x0 | <p>ADC0_KEYDOWN_PENDING.<br/>ADC 0 Key Down IRQ Pending Bit</p> <p>When General key pull down, the status bit is set and the interrupt line is set if the corresponding interrupt is enabled.</p> <p>0: No IRQ<br/>1: IRQ Pending</p> <p>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p> |

|   |     |     |                                                                                                                                                                                           |
|---|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | R/W | 0x0 | ADC0_DATA_PENDING.<br>ADC 0 Data IRQ Pending Bit<br>0: No IRQ<br>1: IRQ Pending<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled. |
|---|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 27.3.4. LRADC Data 0 Register

| Offset: 0x0c |                |                 | Register Name: LRADC_DATA    |
|--------------|----------------|-----------------|------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                  |
| 31:6         | /              | /               | /                            |
| 5:0          | R              | 0x0             | LRADC0_DATA.<br>LRADC 0 Data |

#### 27.3.5. LRADC Data 1 Register

| Offset: 0x10 |                |                 | Register Name: LRADC_DATA    |
|--------------|----------------|-----------------|------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                  |
| 31:6         | /              | /               | /                            |
| 5:0          | R              | 0x0             | LRADC1_DATA.<br>LRADC 1 Data |

## 28. Touch Panel Controller

### 28.1. Overview

The Touch Panel (TP) controller is a 4-wire resistive touch screen controller containing 12-bit resolution A/D converter, and it provides the ability of dual touch detection. In addition to measurable increase in pressure on the touch screen, the controller has been identified by the location of the screen of single touch through the implementation of the two A/D conversion.

It features:

- 12 bit SAR type A/D converter
- 4-wire I/F
- Dual Touch Detect
- Touch-pressure measurement (Support program set threshold)
- Sampling frequency: 2MHz (max)
- Single-Ended Conversion of Touch Screen Inputs and Ratiometric Conversion of Touch Screen Inputs
- TACQ up to 262ms
- Median and averaging filter to reduce noise
- Pen down detection, with programmable sensitivity
- Support X, Y change function

### 28.2. Typical Application Circuit



Figure 28-1 TP Typical Application Circuit

## 28.3. Clock Tree and ADC Time

### 28.3.1. Clock Tree



Figure 28-2 TP Clock Tree

### 28.3.2. A/D Conversion Time

When the clock source is 24MHz and the prescaler value is 6, total 12-bit conversion time is:

$$\text{CLK\_IN} = 24\text{MHz}/6 = 4\text{MHz}$$

$$\text{Conversion Time} = 1/(4\text{MHz}/13\text{Cycles}) = 3.25\mu\text{s}$$

Touch acquire time divider is 16

$$\text{TACQ} = 16 * 1/4\mu\text{s} = 64\mu\text{s}$$

FS\_TIME Based on TACQ and Touch Mode:

When touch is in dual and pressure measurement mode, TACQ is , the FS\_TIME must be no less than  $6 * (\text{TACQ} + \text{Conversion Time})$

$$\text{FS\_TIME} \geq M * (\text{TACQ} + \text{Conversion Time})$$



Figure 28-3.Dual Touch And Pressure Measurement



Figure28-4 Dual Touch No Pressure Measurement



Figure28-5 Single Touch and Pressure Measurement



Figure28-6 Single Touch No Pressure Measurement Mode



Figure28-7 General ADC Mode

## 28.4. Principle of Operation

### 28.4.1. The Basic Principle

The controller is a typical type of successive approximation ADC (SAR ADC), contains a sample/hold, analog-to-digital conversion, serial data output functions. The analog inputs (X+, X-, Y+, Y-) via control register enter the ADC, ADC can be configured as single-ended or differential mode. Selecting Aux ADC or temperature should be configured for single-ended mode; as a touch screen application, it should be configured as a differential mode, which can effectively eliminate the parasitic resistance of the driver switch and external interference caused by measurement error and impact conversion.

accuracy

### 28.4.2. Single-ended Mode

When the TP Control Register 0 Bit12(ADC Mode Select) is high, the controller is in the measurement mode of AUX, Temp, the internal ADC reference voltage source is the single-ended mode, using the AVCC reference source as the ADC reference voltage, application of the principle of single-ended mode shown in Figure 28-8.



Figure 28-8 Simplified Diagram of Single-Ended Reference

### 28.4.3. Differential Mode

When the TP Control Register 0 Bit12(ADC Mode Select) is low, the controller is in the measurement mode of X,Y,Z, the internal ADC reference voltage source is the differential mode, shown in Figure 28-9. The advantage of differential mode: +REF and -REF input directly to the Y+, Y-, which can eliminate measurement error because of the switch on-resistance. The disadvantage is that: both the ample or conversion process, the driver needs to be on, relative to single-ended mode, the power consumption increases.



Figure28-9 Simplified Diagram of Differential Reference

#### 28.4.4. Single Touch Detection

The principle of operation is illustrated below, For an X co-ordinate measurement, the X+ pin is internally switched to AVCC 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 carry no current (hence there is no voltage drop in  $R_{Y+}$  or  $R_{Y-}$ ). Due to the ratiometric 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 co-ordinate measurements are similar to X co-ordinate measurements, with the X and Y plates interchanged. In Single Touch mode, only need to test X+, Y+ signal.



Figure28-10 Single Touch X-Position Measurement

#### 28.4.5. Dual Touch Detection

The principle of operation is illustrated below, For an X co-ordinate measurement, the X+ pin is internally switched to AVCC 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+ and Y-,

which carry no current (hence there is no voltage drop in  $R_{Y+}$  or  $R_{Y-}$ ). Due to the ratiometric 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. the controller will need to test  $X+, X-, Y+, Y-$ , and record  $\Delta X = |X+ - X-|$ ,  $\Delta Y = |Y+ - Y-|$ , if  $\Delta X$  or  $\Delta Y$  great than threshold, as a dual touch, thus as a single touch.



Figure28-11 Dual Touch X-Position Measurements

#### 28.4.6. Touch-Pressure Measurement

The pressure applied to the touch screen by a pen or finger to filter unavailable can also be also be measurement with the controller using some simple calculations. The contact resistance between the X and Y plates is measured, providing a good indication of the size of the depressed area and, therefore, the applied pressure. The area of the spot that is touched is proportional to the size of the object touching it. The size of this resistance ( $R_{touch}$ ) can be calculated using two different methods.

##### First Method:

The first method requires the user to know the total resistance of the X-plate tablet ( $R_X$ ). Three touch screen conversions are required: measurement of the X position, XPOSITION (Y+ 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 Figure 4. The controller have two special ADC channel settings that 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] \quad (1)$$



Figure 28-12 Pressure Measurement Block Diagram

### **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)] \quad (2)$$

#### **28.4.7. Pen Down Detection, with Programmable Sensitivity**

Pen down detection is used as an interrupt to the host.  $R_{IRQ}$  is an internal pull-up resistor with a programmable value of 6~96 kΩ (default 48kΩ). The PENIRQ output is pulled high by an internal pull-up. the Y- driver is on and connected to GND, and the PENIRQ 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 PENIRQ 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 PENIRQ pull-down transistor to eliminate any pull-up resistor leakage current from flowing through the touch screen, thus causing no errors.



Figure 28-13. Example of Pen touch Interrupt via Pen Down IRQ

#### **28.4.8. Median and Averaging Filter**

As explained in the Touch Screen Principles section, 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. Bit1 and Bit0 in Control Register 3(MED1,MED0)set the window of the median filter and, therefore, the number of measurements taken.

| <b>MED1</b> | <b>MED0</b> | <b>Median Filter Size</b> |
|-------------|-------------|---------------------------|
| 0           | 0           | 4                         |
| 0           | 1           | 5                         |
| 1           | 0           | 8                         |
| 1           | 1           | 16                        |

**Table28-1 Median Filter Size**

The averaging filter size determines the number of values to average. Bit5 and Bit4 in Control Register 3 (AVG1, AVG0) set the average to 2, 3, 4, or 8 samples. Only the final averaged result is written into the result FIFO register.

| <b>AVG1</b> | <b>AVG0</b> | <b>Averaging Filter Size</b> |
|-------------|-------------|------------------------------|
| 0           | 0           | 2                            |
| 0           | 1           | 3                            |
| 1           | 0           | 4                            |
| 1           | 1           | 8                            |

**Table28-2 Averaging Filter Size**

When Bit4 of Control Register 3 is set 0, and Median Averaging Filter mode is disabled, only one measurement is transferred to the register map. The number specified with the MED1 and MED0 settings must be greater than or equal to the number specified with the AVG1 and AVG0 settings. If both settings specify the same number, the median filter is switched off.

| <b>Setting</b> | <b>Function</b>                                                                             |
|----------------|---------------------------------------------------------------------------------------------|
| M = A          | Median filter is disabled; output is the average of A converted results                     |
| M > A          | Output is the average of the middle A values from the array of M measurements               |
| M < A          | Not possible because the median filter size is always larger than the averaging window size |

**Table28-3 Median Averaging Filters (MAVF)**

**Example** In this example, MED1, MED0 = 11 and AVG1, AVG0 = 10; 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 28-14 Median and Averaging Filter Example

## 28.5. TP Register List

| Module Name | Base Address |
|-------------|--------------|
| TP          | 0x01C25000   |

| Register Name | Offset | Description                                                  |
|---------------|--------|--------------------------------------------------------------|
| TP_CTRL0      | 0x00   | TP Control Register0                                         |
| TP_CTRL1      | 0x04   | TP Control Register1                                         |
| TP_CTRL2      | 0x08   | TP Pressure Measurement and touch sensitive Control Register |
| TP_CTRL3      | 0x0c   | Median filter Controller Register                            |
| TP_INT_FIFOC  | 0x10   | TP Interrupt FIFO Control Register                           |
| TP_INT_FIFOS  | 0x14   | TP Interrupt FIFO Status Register                            |
| TP_TPR        | 0x18   | TP Temperature Period Register                               |
| TP_DATA       | 0x20   | TP Data Register                                             |

## 28.6. TP Register Description

### 28.6.1. TP Control Register 0

| Offset: 0x00 |                | Register Name: TP_CTRL |                                                                                                   |
|--------------|----------------|------------------------|---------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/Hex        | Description                                                                                       |
| 31:24        | R/W            | 0xF                    | ADC_FIRST_DLY.<br>ADC First Convert Delay setting<br>Based on ADC First Convert Delay Mode select |

|       |     |     |                                                                                                                                             |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | R/W | 0x1 | ADC_FIRST_DLY_MODE.<br>ADC First Convert Delay Mode Select<br>0: CLK_IN/16<br>1: CLK_IN/16*256                                              |
| 22    | R/W | 0x0 | ADC_CLK_SELECT.<br>ADC Clock Source Select:<br>0: HOSC(24MHZ)<br>1: Audio PLL                                                               |
| 21:20 | R/W | 0x0 | 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<br>In TP mode, these two bits must set 1x |
| 19:16 | R/W | 0x0 | FS_DIV.<br>ADC Sample Frequency Divider<br>0000: CLK_IN/2(20-n)<br>0001: CLK_IN/2(20-n)<br>0010: CLK_IN/2(20-n)<br>....<br>1111: CLK_IN/32  |
| 15 :0 | R/W | 0x0 | T_ACQ.<br>Touch panel ADC acquire time<br>CLK_IN/(16*N)                                                                                     |

### 28.6.2. TP control Register 1

| Offset: 0x04 |                |                 | Register Name: TP_CTRL1                                                                                |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------|
| Bit          | Read/<br>Write | Default<br>/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 De-bounce Function Select<br>0: Disable<br>1: Enable                |
| 8:7          | /              | /               | /                                                                                                      |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                   |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6   | R/W | 0x0 | TOUCH_PAN_CALI_EN.<br>Touch Panel Calibration<br>1: start Calibration, it is clear to 0 after calibration                                                                                                                                                                                                                                                                         |
| 5   | R/W | 0x0 | TP_DUAL_EN.<br>Touch Panel Double Point Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                         |
| 4   | R/W | 0x0 | TP_MODE_EN.<br>Tp Mode Function Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                                                 |
| 3   | R/W | 0x1 | TP_ADC_SELECT.<br>Touch Panel and ADC Select<br>0: TP<br>1: ADC                                                                                                                                                                                                                                                                                                                   |
| 2:0 | R/W | 0x0 | ADC_CHAN_SELECT.<br>Analog input channel Select In Normal mode:<br>000: X1 channel<br>001: X2 Channel<br>010: Y1 Channel<br>011: Y2 Channel<br>1xx : 4-channel robin-round<br>FIFO Access Mode,based on this setting. Selecting one channel, FIFO will access that channel data; Selecting four channels FIFO will access each channel data in successive turn, first is X1 data. |

### 28.6.3. TP Control Register 2

| Offset: 0x08 |                |                 | Register Name: TP_CNT2                                                                                                                                                                 |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                            |
| 31:28        | R/W            | 0x8             | TP_SENSITIVE_ADJUST.<br>Internal Pull-up Resistor Control<br>0000 least sensitive<br>0011<br>.....<br>1111 most sensitive<br>Note:<br>Used to adjust sensitivity of pen down detection |
| 27:26        | R/W            | 0x0             | TP_MODE_SELECT.<br>TP Mode Select<br>00: FIFO store X,Y data with Z-filter<br>01: FIFO store X,Y, $\Delta$ X, $\Delta$ Y data with Z-filter                                            |

|      |     |        |                                                                                                                                                                                 |
|------|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |        | 10: FIFO store X,Y, X2,Y2 data with Z-filter<br>11: Debug Mode, FIFO store X1,Y1, X2,Y2,Z1,Z2 data                                                                              |
| 25   | /   | /      | /                                                                                                                                                                               |
| 24   | R/W | 0x0    | PRE_MEA_EN.<br>TP Pressure Measurement Enable Control<br>0: Disable<br>1: Enable                                                                                                |
| 23:0 | R/W | 0xFFFF | PRE_MEA_THRE_CNT.<br>TP Pressure Measurement threshold Control<br>Notes:<br>0x000000: least sensitive<br>0xFFFFFFF: most sensitive<br>Note: used to adjust sensitivity of touch |

#### 28.6.4. Median Filter Control Register

| Offset: 0x0c |                |                 | Register Name: TP_CTRL3                                                  |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:3         | /              | /               | /                                                                        |
| 2            | R/W            | 0x0             | FILTER_EN.<br>Filter Enable<br>0: Disable<br>1: Enable                   |
| 1:0          | R/W            | 0x1             | FILTER_TYPE.<br>Filter Type<br>00: 4/2<br>01: 5/3<br>10: 8/4<br>11: 16/8 |

#### 28.6.5. TP Interrupt& FIFO Control Register

| Offset: 0x10 |                |                 | Register Name: TP_INT                                                        |
|--------------|----------------|-----------------|------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                  |
| 31:19        | /              | /               | 0x0000_0F00                                                                  |
| 18           | R/W            | 0x0             | /                                                                            |
| 17           | R/W            | 0x0             | TP_OVERRUN_IRQ_EN.<br>TP FIFO Over Run IRQ Enable<br>0: Disable<br>1: Enable |
| 16           | R/W            | 0x0             | TP_DATA_IRQ_EN.<br>TP FIFO Data Available IRQ Enable                         |

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

#### 28.6.6. TP Interrupt& FIFO Status Register

| Offset: 0x14 |                |                 | Register Name: TP_FIFOCS                                                                                                                                                                       |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                    |
| 31:19        | /              | /               | /                                                                                                                                                                                              |
| 18           | R/W            | 0x0             | /                                                                                                                                                                                              |
| 17           | R/W            | 0x0             | FIFO_OVERRUN_PENDING.<br>TP FIFO Over Run IRQ pending<br>0: No Pending IRQ<br>1: FIFO Overrun Pending IRQ<br>Write '1' to clear this interrupt or automatic clear if interrupt condition fails |
| 16           | R/W            | 0x0             | FIFO_DATA_PENDING.                                                                                                                                                                             |

|       |     |     |                                                                                                                                                                                                           |
|-------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 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 automatic clear if interrupt condition fails                             |
| 15:13 | /   | /   | /                                                                                                                                                                                                         |
| 12: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/W | 0x0 | TP_UP_PENDING.<br>Touch Panel Last Touch (Stylus Up) IRQ Pending bit<br>0: No IRQ<br>1: IRQ<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable.      |
| 0     | R/W | 0x0 | TP_DOWN_PENDING.<br>Touch Panel First Touch (Stylus Down) IRQ Pending bit<br>0: No IRQ<br>1: IRQ<br>Notes: Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enable. |

#### 28.6.7. TP Temperature Period Register

| Offset: 0x18 |                |                 | Register Name: TP_TPR                           |
|--------------|----------------|-----------------|-------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                     |
| 31:16        | /              | /               | /                                               |
| 16           | R/W            | 0x0             | TEMP_EN.<br>Temperature enable                  |
| 15:0         | R/W            | 0x0             | TEMP_PER.<br>Temperature Period<br>4096*Tclk_in |

#### 28.6.8. Common Data Register

| Offset: 0x1c |                |                 | Register Name: TP_CDAT |
|--------------|----------------|-----------------|------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description            |
| 31:12        | /              | /               | Default: 0x0000_0000   |

|      |     |     |                            |
|------|-----|-----|----------------------------|
| 11:0 | R/W | 0x0 | TP_CDAT.<br>TP Common Data |
|------|-----|-----|----------------------------|

### 28.6.9. TP Data Register

| Offset: 0x24 |                |                 | Register Name: TP_DATA |
|--------------|----------------|-----------------|------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description            |
| 31:12        | /              | /               | /                      |
| 11:0         | R              | 0x0             | /                      |

### 28.6.10. TP Port IO Configure Register

| Offset: 0x28 |                |                 | Register Name: TP_IO_CONFIG                                                                                            |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                            |
| 31:15        | /              | /               | /                                                                                                                      |
| 14:12        | R/W            | 0x2             | TY_N_SELECT<br>TY_N Port Function Select:<br>000: Input 001:Output<br>010: TP_YN 011:/<br>100: / 101:/<br>110: / 111:/ |
| 11           | /              | /               | /                                                                                                                      |
| 10:8         | R/W            | 0x2             | TY_P_SELECT<br>TY_P Port Function Select:<br>000: Input 001:Output<br>010: TP_YP 011:/<br>100: / 101:/<br>110: / 111:/ |
| 7            | /              | /               | /                                                                                                                      |
| 6:4          | R/W            | 0x2             | TX_N_SELECT<br>TX_P Port Function Select:<br>000: Input 001:Output<br>010: TP_XP 011:/<br>100: / 101:/<br>110: / 111:/ |
| 3            | /              | /               | /                                                                                                                      |
| 2:0          | R/W            | 0x2             | TX_P_SELECT<br>TX_P Port Function Select:<br>000: Input 001:Output<br>010: TP_XP 011:/<br>100: / 101:/<br>110: / 111:/ |

### 28.6.11. TP Port Data Register

| Offset: 0x2c |                |                 | Register Name: TP_PORT_DATA                                |
|--------------|----------------|-----------------|------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                |
| 31:12        | /              | /               | /                                                          |
| 3:0          | R/W            | 0x0             | TP_PORT_DATA<br>TP Port Data Value,TP_XP,TP_XN,TP_YP,TP_YN |

## 29. Keypad Interface

### 29.1. Overview

The Keypad Interface is used to connect external keypad devices, which provides up to 8 rows and 8 columns. The events of key press or key release can be detected to the CPU by an interrupt. To prevent switching noises, internal debouncing filter is provided.

The Keypad Interface includes the following features:

- Interrupt for key press or key release
- Internal debouncing filter to prevent the switching noises

### 29.2. Keypad Interface Register List

| Module Name | Base Address |
|-------------|--------------|
| KP          | 0x01C23000   |

| Register Name | Offset | Description                         |
|---------------|--------|-------------------------------------|
| KP_CTL        | 0x00   | Keypad Control Register             |
| KP_TIMING     | 0x04   | Keypad Timing Parameter Register    |
| KP_INT_CFG    | 0x08   | Keypad Interrupt Configure Register |
| KP_INT_STA    | 0x0C   | Keypad Interrupt Status Register    |
| KP_IN0        | 0x10   | Keypad Row Input Data Register 0    |
| KP_IN1        | 0x14   | Keypad Row Input Data Register 1    |

### 29.3. Keypad Interface Register Description

#### 29.3.1. Keypad Control Register

|              |            |         |                                                                                               |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: KP_CTL<br>Default Value: 0x0000_0000                                           |
| Bit          | Read/Write | Default | Description                                                                                   |
| 31:24        | /          | /       | /                                                                                             |
| 23:16        | R/W        | 0       | ROW_INPUT_MSK<br>Keypad Row Input Mask<br>When set to '1', the corresponding input is masked. |
| 15:8         | R/W        | 0       | Keypad Column Output Mask<br>When set to '1', the corresponding output is masked.             |
| 7:1          | /          | /       | /                                                                                             |
| 0            | R/W        | 0       | IF_ENB<br>Keypad Interface enable<br>0: Disable<br>1: Enable                                  |

### 29.3.2. Keypad Timing Register

| Offset: 0x04 |            |         | Register Name: KP_TIMING<br>Default Value: 0x0200_0100                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:16        | R/W        | 0x200   | <p>DBC_CYCLE<br/>Keypad Debounce Clock Cycle n<br/>It is used to filter switching noises. When row input is low level, the Keypad Interface will delay (n+1) clock to check whether it is still on low level. If it is, the Keypad Interface will scan the external keypad state and get these state into internal registers. After scanning, an interrupt is generated if enabled.</p> <p>Notes: The value below 0x10 can't be used.</p> |
| 15:0         | R/W        | 0x100   | <p>SCAN_CYCLE<br/>Keypad Scan Period Clock Cycle n<br/>When the Keypad Interface is enabled, it would scan the external keypad periodically. The period time is <math>8*(n+1)/kp\_clk</math>. The kp_clk is input clock for Keypad Interface from CCM.</p> <p>Note: The value below 0x10 can't be used.</p>                                                                                                                               |

### 29.3.3. Keypad Interrupt Configure Register

| Offset: 0x08 |            |         | Register Name: KP_INT_CFG<br>Default Value: 0x0000_0000                                                      |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                  |
| 31:2         | /          | /       | /                                                                                                            |
| 1            | R/W        | 0       | <p>REDGE_INT_EN<br/>Keypad input rising edge (key release) interrupt enable<br/>0: Disable<br/>1: Enable</p> |
| 0            | R/W        | 0       | <p>FEDGE_INT_EN<br/>Keypad input falling edge (key press) interrupt enable<br/>0: Disable<br/>1: Enable</p>  |

### 29.3.4. Keypad Interrupt Status Register

| Offset: 0x0C |            |         | Register Name: KP_INT_STA<br>Default Value: 0x0000_0000                                                                                                                           |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                       |
| 31:2         | /          | /       | /                                                                                                                                                                                 |
| 1            | R/W        | 0       | <p>REDGE_FLAG<br/>Keypad input rising edge (key release) interrupt status<br/>When it is '1', the key released interrupt occurs.<br/>The interrupt is cleared when write '1'.</p> |
| 0            | R/W        | 0       | FEDGE_FLAG                                                                                                                                                                        |

|  |  |  |                                                                                                                                                                   |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | Keypad input falling edge (key press) interrupt status<br>When it is '1', the corresponding pressed interrupt occurs.<br>The interrupt is cleared when write '1'. |
|--|--|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 29.3.5. Keypad Input Data Register 0

| Offset: 0x10         |            |         | Register Name: KP_IN0<br>Default Value: 0xffff_ffff                 |
|----------------------|------------|---------|---------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                         |
| [8i+7:8i]<br>(i=0~3) | R/W        | 0xff    | COL_STA0<br>Keypad row input byte for column n scan (n from 0 to 3) |

### 29.3.6. Keypad Input Data Register 1

| Offset: 0x14         |            |         | Register Name: KP_IN1<br>Default Value: 0xffff_ffff                 |
|----------------------|------------|---------|---------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                         |
| [8i+7:8i]<br>(i=0~3) | R/W        | 0xff    | COL_STA1<br>Keypad row input byte for column n scan (n from 4 to 7) |

## 29.4. Keypad Interface Special Requirement

### 29.4.1. Keypad Interface Pin List

| Port Name | Width | Direction | Description |
|-----------|-------|-----------|-------------|
| KP_OUT    | 8     | OUT       |             |
| KP_IN     | 8     | IN        |             |

## 30. TV Encoder (TVE)

### 30.1. Overview

The TV Encoder enables the display of digital information on analog television sets as well as the new generation of standard digital televisions, providing a high-quality, flicker-free viewing experience across the key global video standards NTSC and PAL.

### 30.2. TVE Block Diagram



Figure 30-1 TVE Block Diagram

### 30.3. TV Encoder Register List

| Module Name | Base Address |
|-------------|--------------|
| TVE         | 0x01C0A000   |

| Register Name             | Offset | Description                                |
|---------------------------|--------|--------------------------------------------|
| TVE_GCTL_REG              | 0x0000 | TVE Global Control Register                |
| TVE_CFG0_REG              | 0x0004 | TVE Configuration Register0                |
| TVE_DAC_CFG0_REG          | 0x0008 | TVE DAC Configuration Register             |
| TVE_FILTER_REG            | 0x000C | TVE Filter Register                        |
| TVE_CHROMA_FRQ_REG        | 0x0010 | TVE Chroma Frequency Register              |
| TVE_PORCH_NUM_REG         | 0x0014 | TVE Porch Num Register                     |
| TVE_LINE_NUM_REG          | 0x001C | TVE Line Number Register                   |
| TVE_BLANK_BLACK_LEVEL_REG | 0x0020 | TVE Level Register                         |
| TVE_DETECT_REG0           | 0x0030 | TVE Auto Detect Enable Register            |
| TVE_DETECT_REG1           | 0x0034 | TVE Auto Detect Interrupt Status Register  |
| TVE_DETECT_REG2           | 0x0038 | TVE Auto Detection Status Register         |
| TVE_DETECT_REG3           | 0x003C | TVE Auto Detect de-bounce Setting Register |
| TVE_COLOR_BURST_REG       | 0x0100 | TVE Color Burst Phase Reset Register       |
| TVE_VSYNC_NUM_REG         | 0x0104 | TVE VSYNC Number Register                  |

|                        |        |                                         |
|------------------------|--------|-----------------------------------------|
| TVE_NOTCH_FRQ_REG      | 0x0108 | TVE Notch Filter Frequency Register     |
| TVE_CBCR_LEVEL_REG     | 0x010C | TVE Cb Cr Level Register                |
| TVE_BURST_PHASE_REG    | 0x0110 | TVE Tint and Color Burst Phase Register |
| TVE_BURST_WIDTH_REG    | 0x0114 | TVE Burst Width Register                |
| TVE_SYNC_VBI_LEVEL_REG | 0x011C | TVE Sync and VBI Level Register         |
| TVE_WHITE_LEVEL_REG    | 0x0120 | TVE Sync and VBI Level Register         |
| TVE_ACTIVE_NUM_REG     | 0x0124 | TVE Active Num Register                 |
| TVE_CHROMA_BW_GAIN_REG | 0x0128 | TVE Chroma BW and CompGain Register     |
| TVE_NOTCH_WIDTH_REG    | 0x012C | TVE Notch Width Register                |
| TVE_RESYNC_NUM_REG     | 0x0130 | TVE Re-sync Num Register                |
| TVE_SLAVE_PARA_REG     | 0x0134 | TVE Slave Parameter Register            |
| TVE_CFG1_REG           | 0x0138 | TVE Configuration Register1             |
| TVE_CFG2_REG           | 0x013C | TVE Configuration Register2             |

## 30.4. TV Encoder Register Description

### 30.4.1. TVE Global Control Register

| Offset: 0x0000 |                |                 | Register Name: TVE_GCTL_REG                                                                |
|----------------|----------------|-----------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                |
| 31             | R/W            | 0               | TVE_Clk_Gate_Dis<br>1: disable 0: enable                                                   |
| 30:1           | /              | /               | /                                                                                          |
| 0              | R/W            | 0               | TVE_En<br>Video Encoder enable, default disable, write 1 to take it out of the reset state |

### 30.4.2. TVE Configuration Register0

| Offset: 0x0004 |                |                 | Register Name: TVE_CFG0_REG                                              |
|----------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:29          | /              | /               | /                                                                        |
| 28             | R/W            | 0               | /                                                                        |
| 27:21          | /              | /               | /                                                                        |
| 20             | R/W            | 0               | CbCr_Seq<br>0: Cb first<br>1: Cr first<br>Note: this bit is just for 422 |
| 19             | R/W            | 0               | Chroma_Rate<br>0: 444<br>1: 422                                          |
| 18:10          | /              | /               | /                                                                        |

|     |     |   |                                                                                                                                                                                                                                                                                                                                     |
|-----|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9   | R/W | 0 | Colorbar_Type<br>0:<br>NTSC: 75/7.5/75/7.5<br>PAL: 100/0/75/0<br>1:<br>NTSC: 100/7.5/100/7.5<br>PAL: 100/0/100/0                                                                                                                                                                                                                    |
| 8   | R/W | 0 | Colorbar_Mode<br>Standard Color bar input selection<br>This bit selects whether the Video Encoder video data input is replaced by an internal standard color bar generator or not.<br>0: The Video Encoder input comes from the Display Engineer<br>1: The Video Encoder input comes from an internal standard color bar generator. |
| 7:1 | /   | / | /                                                                                                                                                                                                                                                                                                                                   |
| 0   | R/W | 0 | TVE_Mode_Select<br>0: NTSC<br>1: PAL<br>Note: changing this register value will cause some relative register setting to relative value.                                                                                                                                                                                             |

### 30.4.3. TVE DAC Configuration Register

| Offset: 0x0008 |                |                 | Register Name: TVE_DAC_CFG0_REG                                                                        |
|----------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                            |
| 31:28          | /              | /               | /                                                                                                      |
| 27:26          | /              | /               | /                                                                                                      |
| 25:24          | R/W            | 11              | DAC_Mode_Select<br>0: 175 ohms terminal mode<br>2: 75 ohms terminal mode<br>3: 37.5 ohms terminal mode |
| 23:22          | /              | /               | /                                                                                                      |
| 21:17          | R/W            | 0000            | Internal_DAC0_Amplitude_Control<br>00000:smallest<br>11111:biggest                                     |
| 16:13          | /              | /               | /                                                                                                      |
| 12             | R/W            | 1               | Dac_Clk_Polarity                                                                                       |
| 11:8           | /              | /               | /                                                                                                      |
| 7:6            | R/W            | 10              | DAC-REF2<br>00: 0.6<br>01: 0.65<br>10: 0.7<br>11: 0.75                                                 |

|     |     |    |                                                                                                   |
|-----|-----|----|---------------------------------------------------------------------------------------------------|
|     |     |    | connect3, set PbPr detect ref                                                                     |
| 5:4 | R/W | 10 | DAC-REF1(connect2)<br>00: 0.25<br>01: 0.3<br>10: 0.35<br>11: 0.4<br>connect2, set PbPr detect ref |
| 3:1 | /   | /  | /                                                                                                 |
| 0   | R/W | 0  | Internal_DAC0_En<br>0:disable<br>1:enable                                                         |

#### 30.4.4. TVE Filter Register

| Offset: 0x000C |                |                 | Register Name: TVE_FILTER_REG                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:21          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                 |
| 20             | R/W            | 0               | Chroma_Filter_Stage1_Bypass<br>0 : Chroma Filter stage 1 Enable<br>1: Chroma Filter stage 1 bypass                                                                                                                                                                                                                                                                                                |
| 19             | R/W            | 0               | Chroma_Filter_Stage2_Bypass<br>0 : Chroma Filter stage 2 Enable<br>1: Chroma Filter stage 2 bypass                                                                                                                                                                                                                                                                                                |
| 18             | R/W            | 0               | Chroma_Filter_Stage3_Bypass<br>0 : Chroma Filter stage 3 Enable<br>1: Chroma Filter stage 3 bypass                                                                                                                                                                                                                                                                                                |
| 17             | R/W            | 1               | Luma_Filter_Bypass<br>0: Luma Filter Enable<br>1: Luma Filter bypass                                                                                                                                                                                                                                                                                                                              |
| 16             | R/W            | 1               | Notch_En<br>Luma notch filter on/off selection<br>This bit selects whether the luma notch filter operates or is bypassed.<br>0: The luma notch filter is bypassed<br>1: The luma notch filter operates                                                                                                                                                                                            |
| 15:3           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2:0            | R/W            | 4               | YC_Delay<br>luma and chroma paths relative delays (default=4 stages)<br>Relative delay between U/V and Y selection.<br>These bits select the relative delay between the U and V samples and Y samples. The delay ranges from 4 encoder clock cycles of Y lagging the U and V samples to 3 encoder clock cycles of Y preceding the U and V samples.<br>000: The Y lags C by 4 encoder clock cycles |

|  |  |  |                                                                                                                                                                                                                                                                                                                                            |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | 001: The Y lags C by 3 encoder clock cycles<br>010: The Y lags C by 2 encoder clock cycles<br>011: The Y lags C by 1 encoder clock cycle<br>100: There is no delay between the Y and C signals<br>101: The C lags Y by 1 encoder clock cycle<br>110: The C lags Y by 2 encoder clock cycles<br>111: The C lags Y by 3 encoder clock cycles |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 30.4.5. TVE Chroma Frequency Register

| Offset: 0x0010 |                |                 | Register Name: TVE_CHROMA_FRQ_REG                                                                                                                                                                                                                                                                                                                          |
|----------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                |
| 31:0           | R/W            | 21f07c1f        | <b>Chroma_Frq</b><br>Specify the ratio between the color burst frequency. 32 bit unsigned fraction. Default value is h21f07c1f, which is compatible with NTSC specs.<br>3.5795455MHz (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 |

#### 30.4.6. TVE Porch Num Register

| Offset: 0x0014 |                |                 | Register Name: TVE_PORCH_NUM_REG                                                                                                                                                 |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                      |
| 31:25          | /              | /               | /                                                                                                                                                                                |
| 24:16          | R/W            | 76              | <b>Back_Porch</b><br>Specify the width of the back porch in encoder clock cycles. Min value is (burst_width+breeze_way+17). 8 bit unsigned integer. Default value is 118         |
| 15:12          | /              | /               | /                                                                                                                                                                                |
| 11:0           | R/W            | 20              | <b>Front_Porch</b><br>must be even<br>Specify the width of the front porch in encoder clock cycles. 6 bit unsigned even integer. Allowed range is 10 to 62. Default value is 32. |

#### 30.4.7. TVE Line Number Register

| Offset: 0x001C |                |                 | Register Name: TVE_LINE_NUM_REG                                                                         |
|----------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                             |
| 31:24          | /              | /               | /                                                                                                       |
| 23:16          | R/W            | 16              | <b>First_Video_Line</b><br>Specify the index of the first line in a field/frame to have active video. 8 |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | bit unsigned integer.<br>For interlaced video: When VSync5=B'0', FirstVideoLine is restricted to be larger than 7. When VSync5=B'1', FirstVideoLine is restricted to be larger than 9. Default value is 21.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:11 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 10:0  | R/W | 20D | Num_Lines<br>Specify the total number of lines in a video frame. 11 bit unsigned integer. Allowed range is 0 to 2048. Default value is 525.<br>For interlaced video: When NTSC, and FirstVideoLine is larger than 20, then NumLines is restricted to be larger than 2*(FirstVideoLine+18). When NTSC, and FirstVideoLine is not larger than 20, then NumLines is restricted to be larger than 77. When PAL, and FirstVideoLine is larger than 22, then NumLines is restricted to be larger than 2*(FirstVideoLine+18). When PAL, and FirstVideoLine is not larger than 22, then NumLines is restricted to be larger than 81.<br>If NumLines is even, it is restricted to be divisible by 4. If NumLines is odd, it is restricted to be divisible by 4 with a remainder of 1. |

#### 30.4.8. TVE Black Level Register

| Offset: 0x0020 |                |                 | Register Name: TVE_BLANK_BLACK_LEVEL_REG                                                                                                           |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                        |
| 31:26          | /              | /               | /                                                                                                                                                  |
| 25:16          | R/W            | 0f0             | Blank_Level<br>Specify the blank level setting for active lines. 10 bit unsigned integer. Allowed range 0 to 1023. Default value is hexF0(dec240). |
| 15:10          | /              | /               | /                                                                                                                                                  |
| 9:0            | R/W            | 11a             | Black_Level<br>Specify the black level setting. 10 bit unsigned integer. Allowed range is 240 to 1023. Default value is 282                        |

#### 30.4.9. TVE Auto Detect Enable Register

| Offset: 0x0030 |                |                 | Register Name: TVE_DETECT_REG0 |
|----------------|----------------|-----------------|--------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                    |
| 31:17          | /              | /               | /                              |
| 16             | R/W            | 0               | DAC0_Auto_Det_Int_En           |
| 15:1           | /              | /               | /                              |
| 0              | R/W            | 0               | DAC0_Auto_Det_En               |

#### 30.4.10. TVE Auto Detect Interrupt Status Register

| Offset: 0x0034 |        |          | Register Name: TVE_DETECT_REG1 |
|----------------|--------|----------|--------------------------------|
| Bit            | Read/W | Default/ | Description                    |

|      | rite | Hex |                                                                             |
|------|------|-----|-----------------------------------------------------------------------------|
| 31:1 | /    | /   | /                                                                           |
| 0    | R/W  | 0   | DAC0_Auto_Det_Int_Flag<br>write 1 to inactive DAC0 auto detection interrupt |

#### 30.4.11. TVE Auto Detection Status Register

| Offset: 0x0038 |                |                 | Register Name: TVE_DETECT_REG2                                                         |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                            |
| 31:2           | /              | /               | /                                                                                      |
| 1:0            | R/W            | 0               | DAC0_Status<br>00: Unconnected<br>01: Connected<br>11: Short to ground<br>10: Reserved |

#### 30.4.12. TVE Auto Detect de-bounce Setting Register

| Offset: 0x003C |                |                 | Register Name: TVE_DETECT_REG3 |
|----------------|----------------|-----------------|--------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                    |
| 31:26          | /              | /               | /                              |
| 25:16          | R/W            | 0               | DAC_Test_Value                 |
| 15:4           | /              | /               | /                              |
| 3:0            | R/W            | 0               | DAC0_DeBounce_Times            |

#### 30.4.13. TVE Color Burst Phase Reset Register

| Offset: 0x0100 |                |                 | Register Name: TVE_COLOR_BURST_REG                                                                                                                                                                                                                                                                                                      |
|----------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                             |
| 31:2           | /              | /               | Reserved                                                                                                                                                                                                                                                                                                                                |
| 1:0            | R/W            | 1               | Color_Phase_Reset<br>Color burst phase period selection<br>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 applied only to interlaced video.<br>0 – 8 field<br>1 – 4 field<br>2 – 2 lines<br>3 – only once |

#### 30.4.14. TVE Vsync Number Register

|                |                                  |
|----------------|----------------------------------|
| Offset: 0x0104 | Register Name: TVE_VSYNC_NUM_REG |
|----------------|----------------------------------|

| Bit  | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                     |
|------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1 | /              | /               | /                                                                                                                                                                                                                                                                               |
| 0    | R/W            | 0               | <p>VSync5</p> <p>Number of equalization pulse selection</p> <p>This bit selects whether the number of equalization pulses is 5 or 6.</p> <p>This parameter is applicable only to interlaced video</p> <p>0 – 6 equalization pulse(default)</p> <p>1 – 5 equalization pulses</p> |

### 30.4.15. TVE Notch Filter Frequency Register

| Offset: 0x0108 |                |                 | Register Name: TVE_NOTCH_FRQ_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:3           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2:0            | R/W            | 2               | <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</p> <p>001: 1.1406</p> <p>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> <p>011: 0.9922. This selection is proper for NTSC with square pixels</p> <p>100: 0.9531. This selection is proper for PAL with square pixel</p> <p>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'</p> <p>110: 0.7813</p> <p>111: 0.7188</p> <p>Default value is B'010'.</p> |

### 30.4.16. TVE Cb Cr Level Register

| Offset: 0x010C |                |                 | Register Name: TVE_CBCR_LEVEL_REG                                                                                                                     |
|----------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                           |
| 31:16          | /              | /               | /                                                                                                                                                     |
| 15:8           | R/W            | 0               | <p>Cr_Burst_Level</p> <p>Specify the amplitude of the Cr burst. 8 bit 2's complement integer. Allowed range is (-127) to 127. Default value is 0.</p> |
| 7:0            | R/W            | 3C              | <p>Cb_Burst_Level</p> <p>Specify the amplitude of the Cb burst. 8 bit 2's complement integer. Allowed range is (-127) to 127. Default value is 60</p> |

### 30.4.17. TVE Tint and Color Burst Phase Register

| Offset: 0x0110 |                |                 | Register Name: TVE_BURST_PHASE_REG                                                                                                                                                                                                                                                                                                                            |
|----------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                   |
| 31:24          | /              | /               | /                                                                                                                                                                                                                                                                                                                                                             |
| 23:16          | R/W            | 0               | Tint<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. Default value is 0.                                                                                  |
| 15:8           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                             |
| 7:0            | R/W            | 0               | Chroma_Phase<br>Specify the color burst initial phase (ChromaPhase). 8.8 bit unsigned fraction. Units are cycles of the color burst frequency. Default value is X'00'. 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) |

### 30.4.18. TVE Burst Width Register

| Offset: 0x0114 |                |                 | Register Name: TVE_BURST_WIDTH_REG                                                                                                                                                                                                                       |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                              |
| 31:23          | /              | /               | /                                                                                                                                                                                                                                                        |
| 22:16          | R/W            | 16              | Breezeway<br>Must be even<br>Specify the width of the breezeway in encoder clock cycles. 5 bit unsigned integer. Allowed range is 0 to 31. Default value is 22                                                                                           |
| 15             | /              | /               | /                                                                                                                                                                                                                                                        |
| 14:8           | R/W            | 44              | Burst_Width<br>Specify the width of the color frequency burst in encoder clock cycles. 7 bit unsigned integer. Allowed range is 0 to 127. Default value is 68.                                                                                           |
| 7:0            | R/W            | 7E              | HSync_Width<br>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. |

### 30.4.19. TVE\_CBCR\_GAIN\_REG

| Offset: 0x0118 |                |                 | Register Name: TVE_Cb Cr Gain Register |
|----------------|----------------|-----------------|----------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                            |
| 31:16          | /              | /               | /                                      |

|      |     |    |                                                                                      |
|------|-----|----|--------------------------------------------------------------------------------------|
| 15:8 | R/W | 89 | Cr_Gain<br>Specify the Cr color gain. 8 bit unsigned fraction. Default value is 139  |
| 7:0  | R/W | 89 | Cb_Gain<br>Specify the Cb color gain. 8 bit unsigned fraction. Default value is 139. |

### 30.4.20. TVE Sync and VBI Level Register

| Offset: 0x011C |                |                 | Register Name: TVE_SYNC_VBI_LEVEL_REG                                                                                                                                           |
|----------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                     |
| 31:26          | /              | /               | /                                                                                                                                                                               |
| 25:16          | R/W            | 48              | Sync_Level<br>Specify the sync pulse level setting. 8 bit unsigned integer. Allowable range is 0 to ABlankLevel-1 or VBlankLevel-1 (whichever is smaller). Default value is 72. |
| 15:10          | /              | /               | /                                                                                                                                                                               |
| 9:0            | R/W            | 128             | VBlank_Level<br>Specify the blank level setting for non active lines. 10 bit unsigned integer. Allowable range is 0 to 1023. Default value is hex128(dec296)                    |

### 30.4.21. TVE Sync and VBI Level Register

| Offset: 0x0120 |                |                 | Register Name: TVE_WHITE_LEVEL_REG                                                                                                                                                  |
|----------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                         |
| 31:10          | /              | /               | /                                                                                                                                                                                   |
| 9:0            | R/W            | 320             | White_Level<br>Specify the white level setting. 10 bit unsigned integer. Allowed range is black_level+1 or vbi_blank_level +1 (whichever is greater) to 1023. Default value is 800. |

### 30.4.22. TVE Active Num Register

| Offset: 0x0124 |                |                 | Register Name: TVE_ACTIVE_NUM_REG                                                                                                                                    |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                          |
| 31:12          | /              | /               | /                                                                                                                                                                    |
| 11:0           | R/W            | 5A0             | Active_Line<br>Specify the width of the video line in encoder clock cycles. 12 bit unsigned multiple of 4 integer. Allowed range is 0 to 4092 Default value is 1440. |

### 30.4.23. TVE Chroma BW and CompGain Register

| Offset: 0x0128 |        |          | Register Name: TVE_CHROMA_BW_GAIN_REG |
|----------------|--------|----------|---------------------------------------|
| Bit            | Read/W | Default/ | Description                           |

|       | rite | Hex |                                                                                                                                                                                                                                                                       |
|-------|------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | /    | /   | /                                                                                                                                                                                                                                                                     |
| 17:16 | R/W  | 00  | <p>Chroma_BW<br/>Chroma filter bandwidth selection<br/>This bit specifies whether the bandwidth of the chroma filter is:<br/>0- Narrow width, 0.7MHz<br/>1- Wide width 1.2MHz.<br/>2- Extra width 1.8MHz<br/>3- Ultra width 2.5MHz<br/>Default is 0.6MHz(value 0)</p> |
| 15:2  | /    | /   | /                                                                                                                                                                                                                                                                     |
| 1:0   | R/W  | 0   | <p>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: 100% (B'00'), 75% (B'11'), 50% (B'10') or 25% (B'01').</p>  |

#### 30.4.24. TVE Notch Width Register

| Offset: 0x012C |                |                 | Register Name: TVE_NOTCH_WIDTH_REG                                                                                                                                   |
|----------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                          |
| 31:9           | /              | /               | /                                                                                                                                                                    |
| 8              | R/W            | 0               | <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:0            | /              | /               | /                                                                                                                                                                    |

#### 30.4.25. TVE Re-sync Num Register

| Offset: 0x0130 |                |                 | Register Name: TVE_RESYNC_NUM_REG              |
|----------------|----------------|-----------------|------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                    |
| 31             | R/W            | 0               | ReSync_Field                                   |
| 30             | R/W            | 0               | <p>ReSync_Dis<br/>0: Enable<br/>1: Disable</p> |
| 29:27          | /              | /               | /                                              |
| 26:16          | R/W            | 0               | ReSync_Line_Number                             |
| 15:11          | /              | /               | /                                              |
| 10:0           | R/W            | 0               | ReSync_Pixel_Number                            |

### 30.4.26. TVE Slave Parameter Register

| Offset: 0x0134 |                |                 | Register Name: TVE_SLAVE_PARA_REG                                                                                                                                                                                                                                                                 |
|----------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                       |
| 31:9           | /              | /               | /                                                                                                                                                                                                                                                                                                 |
| 8              | R/W            | 0               | <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 0 or 30.<br/>0 – Number of lines is 0<br/>1 – Number of lines is 30<br/>Default values is 0</p> |
| 7:1            | /              | /               | /                                                                                                                                                                                                                                                                                                 |
| 0              | R/W            | 0               | <p>Slave_Mode<br/>Slave mode selection<br/>This bit selects whether the Video Encoder is sync slave, partial slave or sync master. 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: /</p>                       |

### 30.4.27. TVE Configuration Register1

| Offset: 0x0138 |                |                 | Register Name: TVE_CFG1_REG                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:9           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8              | R/W            | 0               | <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:0            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                |

### 30.4.28. TVE Configuration Register2

| Offset: 0x013C |                |                 | Register Name: TVE_CFG2_REG                 |
|----------------|----------------|-----------------|---------------------------------------------|
| Bit            | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:1           | /              | /               | /                                           |
| 0              | R/W            | 0               | Bypass_YClamp<br>Y input clamping selection |

|  |  |  |                                                                                                                                                                                                                                                                                                              |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>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 of 64 to 960.</p> <p>0: The Video Encoder Y input is clamped<br/>1: The Video Encoder Y input is not clamped</p> |
|--|--|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

# 31. CSI

## 31.1. Overview

The CSI features:

- 8 bits input data
- Support CCIR656 protocol for NTSC and PAL
- 3 parallel data paths for image stream parsing
- Support Received data double buffer
- Parsing bayer data into planar R, G, B output to memory
- Parsing interlaced data into planar or MB Y, Cb, Cr output to memory
- Pass raw data direct to memory
- All data transmit timing can be adjusted by software
- Luminance statistical value

## 31.2. CSI Block Diagram



Figure 31-1 CSI Block Diagram

## 31.3. CSI Register List

| Module Name | Base Address |
|-------------|--------------|
| CSI         | 0x01C00900   |

| Register Name            | Offset | Description                   |
|--------------------------|--------|-------------------------------|
| CSI_EN_REG               | 0x0000 | CSI Enable Register           |
| CSI_CFG_REG              | 0x0004 | CSI Configuration Register    |
| CSI_CPT_CTRL_REG         | 0x0008 | CSI Capture Control Register  |
| CSI_FIFO0_BUF_A_ADDR_REG | 0x0010 | CSI FIFO0 Buffer A Register   |
| CSI_FIFO0_BUF_B_ADDR_REG | 0x0014 | CSI FIFO0 Buffer B Register   |
| CSI_FIFO1_BUF_A_ADDR_REG | 0x0018 | CSI FIFO1 Buffer A Register   |
| CSI_FIFO1_BUF_B_ADDR_REG | 0x001C | CSI FIFO1 Buffer B Register   |
| CSI_BUF_CTRL_REG         | 0x0028 | CSI Buffer Control Register   |
| CSI_STA_REG              | 0x002C | CSI Status Register           |
| CSI_INT_EN_REG           | 0x0030 | CSI Interrupt Enable Register |

|                    |        |                                    |
|--------------------|--------|------------------------------------|
| CSI_INT_STA_REG    | 0x0034 | CSI Interrupt Status Register      |
| CSI_WIN_CTRL_W_REG | 0x0040 | CSI Window Width Control Register  |
| CSI_WIN_CTRL_H_REG | 0x0044 | CSI Window Height Control Register |
| CSI_BUF_LEN_REG    | 0x0048 | CSI Buffer Length Register         |

## 31.4. CSI Register Description

### 31.4.1. CSI Enable Register

| Offset: 0X0000 |                |                 | Name: CSI_EN_REG<br>Default Value: 0X00000000         |
|----------------|----------------|-----------------|-------------------------------------------------------|
| Bit            | Read/<br>Write | Default/He<br>x | Description                                           |
| 31:01          | /              | /               | Reserved                                              |
| 00             | R/W            | 0               | EN<br>CSI Enable<br>0: Reset and disable<br>1: Enable |

### 31.4.2. CSI Configuration Register

| Offset Address: 0X0004 |                |                 | Register Name: CSI_CFG_REG<br>Default Value: 0X00000000                                                                                                                                                                                                                                                                                                                      |
|------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                  |
| 31:23                  | /              | /               | Reserved                                                                                                                                                                                                                                                                                                                                                                     |
| 22:20                  | R/W            | 0               | IN_FMT<br>Input data format<br>000: RAW stream<br>010: CCIR656<br>011: YUV422<br>others: reserved                                                                                                                                                                                                                                                                            |
| 19:16                  | R/W            | 0               | OUT_FMT<br>Output data format<br>When the input format is set RAW stream<br>0000: pass-through<br><br>When the input format is set CCIR656 interface<br>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<br>0101: field planar YCbCr 420 UV combined |

|       |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | <p>0110: frame planar YCbCr 420 UV combined<br/>     0111: frame planar YCbCr 422 UV combined<br/>     1111: interlaced interleaved YCbCr422. In this mode, capturing interlaced input and output the interlaced fields from individual ports. Field 1 data will be written to FIFO0 output buffer and field 2 data will be written to FIFO1 output buffer.<br/>     1000: field MB YCbCr 422<br/>     1001: field MB YCbCr 420<br/>     1010: frame MB YCbCr 420<br/>     1011: frame MB YCbCr 422</p> <p>When the input format is set YUV422<br/>     0000: planar YUV 422<br/>     0001: planar YUV 420<br/>     0100: planar YUV 422 UV combined<br/>     0101: planar YUV 420 UV combined<br/>     1000: MB YUV 422<br/>     1001: MB YUV 420</p> |
| 15:12 | /   | / | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11:10 | R/W | 0 | <p><b>FIELD_SEL</b><br/>     Field selection. Applies to CCIR656 interface only.<br/>     00: start capturing with field odd.<br/>     01: start capturing with field even.<br/>     10: start capturing with either field.<br/>     11: reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 09:08 | R/W | 2 | <p><b>DATA_SEQ</b><br/>     Input data sequence, only valid for YUV422 mode.<br/>     00: YUYV<br/>     01: YVYU<br/>     10: UYVY<br/>     11: VYUY</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 07:03 | /   | / | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 02    | R/W | 0 | <p><b>VSYNC_POL</b><br/>     Vref polarity<br/>     0: negative<br/>     1: positive<br/>     This register is not applied to CCIR656 interface.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 01    | R/W | 0 | <p><b>Hsync_POL</b><br/>     Href polarity<br/>     0: negative<br/>     1: positive<br/>     This register is not applied to CCIR656 interface.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 00    | R/W | 0 | PCLK_POL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

|  |  |  |                                                                          |
|--|--|--|--------------------------------------------------------------------------|
|  |  |  | Data clock type<br>0: active in falling edge<br>1: active in rising edge |
|--|--|--|--------------------------------------------------------------------------|

### 31.4.3. CSI Capture Control Register

| Offset Address: 0X0008 |                |                 | Register Name: CSI_CPT_CTRL_REG<br>Default Value: 0X00000000                                                                                                                                                                                                                                                                                                                            |
|------------------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                             |
| 31:02                  | /              | /               | Reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 01                     | R/W            | 0               | <b>VIDEO_CAP_CTRL</b><br>Video capture control: Capture the video image data stream.<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. |
| 00                     | W              | 0               | <b>STILL_CAP_CTRL</b><br>Still capture control: Capture a single still image frame.<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.                                                       |

### 31.4.4. CSI FIFO0 Buffer A Register

| Offset Address: 0X0010 |                |                 | Register Name: CSI_FIFO0_BUF_A_ADDR_REG<br>Default Value: 0X00000000 |
|------------------------|----------------|-----------------|----------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/<br>Hex | Description                                                          |
| 31:00                  | R/W            | 0               | FIFO0_BUF_A<br>FIFO0 output buffer-A address                         |

### 31.4.5. CSI FIFO0 Buffer B Register

| Offset Address: 0X0014 |                |                 | Register Name: CSI_FIFO0_BUF_B_ADDR_REG<br>Default Value: 0X00000000 |
|------------------------|----------------|-----------------|----------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/<br>Hex | Description                                                          |
| 31:00                  | R/W            | 0               | FIFO0_BUF_B<br>FIFO0 output buffer-B address                         |

#### **31.4.6. CSI FIFO1 Buffer A Register**

| Offset Address: 0X0018 |             |              | Register Name: CSI_FIFO1_BUF_A_ADDR_REG<br>Default Value: 0X00000000 |
|------------------------|-------------|--------------|----------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                          |
| 31:00                  | R/W         | 0            | FIFO1_BUF_A<br>FIFO1 output buffer-A address                         |

#### **31.4.7. CSI FIFO1 Buffer B Register**

| Offset Address: 0X001C |             |              | Register Name: CSI_FIFO1_BUF_B_ADDR_REG<br>Default Value: 0X00000000 |
|------------------------|-------------|--------------|----------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                          |
| 31:00                  | R/W         | 0            | FIFO1_BUF_B<br>FIFO1 output buffer-B address                         |

#### **31.4.8. CSI Buffer Control Register**

| Offset Address: 0X0028 |             |              | Register Name: CSI_BUF_CTRL_REG<br>Default Value: 0X00000000                                                                                              |
|------------------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                                                                                                               |
| 31:02                  | /           | /            | Reserved                                                                                                                                                  |
| 01                     | R           | 0            | DBS<br>output buffer selected status<br>0: Selected output buffer-A<br>1: Selected output buffer-B                                                        |
| 00                     | R/W         | 0            | DBE<br>Double buffer mode enable<br>0: disable<br>1: enable<br>If the double buffer mode is disabled, the buffer-A will be always selected by CSI module. |

#### **31.4.9. CSI Status Register**

| Offset Address: 0X002C |             |              | Register Name: CSI_STA_REG<br>Default Value: 0X00000000                                                                                   |
|------------------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                                                                                               |
| 31:08                  | R           | 0            | LUM_STAT_VALUE<br>luminance statistical value<br>When frame done interrupt flag come, value is ready and will last until next frame done. |

|       |    |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|----|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |    |   | For raw data, value = $(G>>1+R+G)>>8$<br>For yuv422, value = $Y>>8$                                                                                                                                                                                                                                                                                                                                                                                                             |
| 07:02 | /- | / | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 01    | R  | 0 | <p><b>VIDEO_CAP_ON</b><br/>         Video capture in progress<br/>         Indicates the CSI is capturing video image data (multiple frames). The bit is set at the start of the first frame after enabling video capture. When software disables video capture, it clears itself after the last pixel of the current frame is captured.</p>                                                                                                                                    |
| 00    | R  | 0 | <p><b>STILL_CPT_ON</b><br/>         Still capture in progress<br/>         Indicates the CSI is capturing still image data (single frame). The bit is set at the start of the first frame after enabling still frame capture. It is self-cleared 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, and the other frame end means filed end.</p> |

### 31.4.10. CSI Interrupt Enable Register

| Offset Address: 0X0030 |                |                 | Register Name: CSI_INT_EN_REG<br>Default Value: 0X00000000                                                                                                                                                                                   |
|------------------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                    | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                                                                                                                                                                  |
| 31:08                  | /              | /               | Reserved                                                                                                                                                                                                                                     |
| 07                     | R/W            | 0               | <p><b>VSYNC_FLAG</b><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 comes, change the buffer address could only affect next frame</p> |
| 06                     | R/W            | 0               | <p><b>HB_OF</b><br/>         Hblank FIFO overflow<br/>         The bit is set when 3 FIFOs still overflow after the hblank.</p>                                                                                                              |
| 05                     | R/W            | 0               | <p><b>PRT_ERR</b><br/>         Protection error<br/>         Indicates a protection error has been detected. Applies only when the 656 protocol is selected.</p>                                                                             |
| 04                     | /              | /               | Reserved                                                                                                                                                                                                                                     |
| 03                     | R/W            | 0               | <p><b>FIFO0_OF</b><br/>         FIFO1 overflow<br/>         The bit is set when the FIFO 1 overflows.</p>                                                                                                                                    |
| 02                     | R/W            | 0               | <p><b>FIFO0 overflow</b><br/>         The bit is set when the FIFO 0 overflows.</p>                                                                                                                                                          |

|    |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 01 | R/W | 0 | FRM_DONE<br>Frame done<br>Indicates the CSI finishes capturing an image frame. Applied 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.                                                                                                                                                                                                                       |
| 00 | R/W | 0 | CPT_DONE<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 is disabled.<br>For CCIR656 interface, if the output format is frame planar YCbCr 420 mode, the frame end means the field2 end, and the other frame end means field end. |

#### 31.4.11. CSI Interrupt Status Register

| Offset Address: 0X0034 |             |              | Register Name: CSI_INT_STA_REG<br>Default Value: 0X00000000 |
|------------------------|-------------|--------------|-------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                 |
| 31:08                  | /           | /            | Reserved                                                    |
| 07                     | R/W         | 0            | VSYNC_FLAG<br>vsync flag                                    |
| 06                     | R/W         | 0            | HB_OF<br>Hblank FIFO overflow                               |
| 05                     | R/W         | 0            | PRT_ERR<br>Protection error                                 |
| 04                     | /           | /            | Reserved                                                    |
| 03                     | R/W         | 0            | FIFO1_OF<br>FIFO1 overflow                                  |
| 02                     | R/W         | 0            | FIFO0_OF<br>FIFO0 overflow                                  |
| 01                     | R/W         | 0            | FRM_DONE<br>Frame done                                      |
| 00                     | R/W         | 0            | CPT_DONE<br>Capture done                                    |

#### 31.4.12. CSI Window Width Control Register

| Offset Address: 0X0040 |         |          | Register Name: CSI_WIN_CTRL_W_REG<br>Default Value: 0X00000000 |
|------------------------|---------|----------|----------------------------------------------------------------|
| Bit                    | Read/Wr | Default/ | Description                                                    |

|       | ite | Hex |                                                                                    |
|-------|-----|-----|------------------------------------------------------------------------------------|
| 31:29 | /   | /   | Reserved                                                                           |
| 28:16 | R/W | 500 | ACTIVE_LEN<br>Horizontal pixel clock length. Valid pixel clocks of a line.         |
| 15:13 | /   | /   | Reserved                                                                           |
| 12:00 | R/W | 0   | ACTIVE_START<br>Horizontal pixel clock start. Pixel data is valid from this clock. |

### 31.4.13. CSI Window Height Control Register

| Offset Address: 0X0044 |             |              | Register Name: CSI_WIN_CTRL_H_REG<br>Default Value: 0X00000000     |
|------------------------|-------------|--------------|--------------------------------------------------------------------|
| Bit                    | Read/Wr ite | Default/ Hex | Description                                                        |
| 31:29                  | /           | /            | Reserved                                                           |
| 28:16                  | R/W         | 0x1E0        | ACTIVE_LEN<br>Vertical line length. Valid line number of a frame.  |
| 15:13                  | /           | /            | Reserved                                                           |
| 12:00                  | R/W         | 0            | ACTIVE_START<br>Vertical line start. data is valid from this line. |

### 31.4.14. CSI Buffer Length Register

| Offset: 0X0048 |             |              | Register Name: CSI_BUF_LEN_REG<br>Default Value: 0X00000000         |
|----------------|-------------|--------------|---------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                         |
| 31:13          | /           | /            | Reserved                                                            |
| 12:00          | R/W         | 0x280        | BUFF_LEN<br>Buffer Length<br>Buffer length of a line. Unit is byte. |

## 31.5. CCIR656 Format

### 31.5.1. Header Data Bit Definition

| Data Bit      | First Word(0xFF) | Second Word (0x00) | Third Word(0x00) | Fourth Word |
|---------------|------------------|--------------------|------------------|-------------|
| CS D[7] (MSB) | 1                | 0                  | 0                | 1           |
| CS D[6]       | 1                | 0                  | 0                | F           |
| CS D[5]       | 1                | 0                  | 0                | V           |
| CS D[4]       | 1                | 0                  | 0                | H           |
| CS D[3]       | 1                | 0                  | 0                | P3          |
| CS D[2]       | 1                | 0                  | 0                | P2          |
| CS D[1]       | 1                | 0                  | 0                | P1          |
| CS D[0]       | 1                | 0                  | 0                | P0          |

### 31.5.2. CCIR656 Header Decode

| Decode                              | F | V | H | P3 | P2 | P1 | P0 |
|-------------------------------------|---|---|---|----|----|----|----|
| Field 1 start of active video (SAV) | 0 | 0 | 0 | 0  | 0  | 0  | 0  |
| Field 1 end of active video (EAV)   | 0 | 0 | 1 | 1  | 1  | 0  | 1  |
| Field 1 SAV (digital blanking)      | 0 | 1 | 0 | 1  | 0  | 1  | 1  |
| Field 1 EAV (digital blanking)      | 0 | 1 | 1 | 0  | 1  | 1  | 0  |
| Field 2 SAV                         | 1 | 0 | 0 | 0  | 1  | 1  | 1  |
| Field 2 EAV                         | 1 | 0 | 1 | 1  | 0  | 1  | 0  |
| Field 2 SAV (digital blanking)      | 1 | 1 | 0 | 1  | 1  | 0  | 0  |
| Field 2 EAV (digital blanking)      | 1 | 1 | 1 | 0  | 0  | 0  | 1  |

## 31.6. CSI Timing Diagram



## 32. Display Engine Front End

### 32.1. Overview

The Display Engine Front End (DEFE) performs image capture/driver, video/graphic scale, format conversion and color space conversion. It is composed of DMA controller, input controller, scaler, color space conversion and output controller as show in figure 32-1.

The DEFE features:

- Output scan type: interlace/progressive
- Input format: YUV444/YUV422/YUV420/YUV411/RGB
- Direct display output format: RGB
- Write back output format: RGB/YUV444/YUV420/YUV422/YUV411
- 3 channel scaling pipelines for scaling up/down
- Programmable source image size from 8x4 to 8192x8192 resolution
- Programmable destination image size from 8x4 to 8192x8192 resolution
- 4 tap scale filter in horizontal and vertical direction
- 32 Programmable coefficients for each tap
- Color space conversion between YUV and RGB
- Support direct display and write back to memory

### 32.2. DEFE Block Diagram



Figure 32-1 DEFE Block Diagram

### 32.3. DEFE Register List

| Module Name | Base Address |
|-------------|--------------|
| DEFE0       | 0x01E00000   |

| Register Name | Offset | Description |
|---------------|--------|-------------|
|               |        |             |

|                         |        |                                                  |
|-------------------------|--------|--------------------------------------------------|
| DEFE_EN_REG             | 0x0000 | DEFE Module Enable Register                      |
| DEFE_FRM_CTRL_REG       | 0x0004 | DEFE Frame Process Control Register              |
| DEFE_BYPASS_REG         | 0x0008 | DEFE CSC By-Pass Register                        |
| DEFE_AGTH_SEL_REG       | 0x000C | DEFE Algorithm Selection Register                |
| DEFE_LINT_CTRL_REG      | 0x0010 | DEFE Line Interrupt Control Register             |
| DEFE_BUF_ADDR0_REG      | 0x0020 | DEFE Input Channel 0 Buffer Address Register     |
| DEFE_BUF_ADDR1_REG      | 0x0024 | DEFE Input Channel 1 Buffer Address Register     |
| DEFE_BUF_ADDR2_REG      | 0x0028 | DEFE Input Channel 2 Buffer Address Register     |
| DEFE_FIELD_CTRL_REG     | 0x002C | DEFE Field Sequence Register                     |
| DEFE_TB_OFF0_REG        | 0x0030 | DEFE Channel 0 Tile-Based Offset Register        |
| DEFE_TB_OFF1_REG        | 0x0034 | DEFE Channel 1 Tile-Based Offset Register        |
| DEFE_TB_OFF2_REG        | 0x0038 | DEFE Channel 2 Tile-Based Offset Register        |
| DEFE_LINESTRD0_REG      | 0x0040 | DEFE Channel 0 Line Stride Register              |
| DEFE_LINESTRD1_REG      | 0x0044 | DEFE Channel 1 Line Stride Register              |
| DEFE_LINESTRD2_REG      | 0x0048 | DEFE Channel 2 Line Stride Register              |
| DEFE_INPUT_FMT_REG      | 0x004C | DEFE Input Format Register                       |
| DEFE_WB_ADDR0_REG       | 0x0050 | DEFE Channel 3 Write Back Address Register       |
| DEFE_OUTPUT_FMT_REG     | 0x005C | DEFE Output Format Register                      |
| DEFE_INT_EN_REG         | 0x0060 | DEFE Interrupt Enable Register                   |
| DEFE_INT_STATUS_REG     | 0x0064 | DEFE Interrupt Status Register                   |
| DEFE_STATUS_REG         | 0x0068 | DEFE Status Register                             |
| DEFE_CSC_COEF00_REG     | 0x0070 | DEFE CSC Coefficient 00 Register                 |
| DEFE_CSC_COEF01_REG     | 0x0074 | DEFE CSC Coefficient 01 Register                 |
| DEFE_CSC_COEF02_REG     | 0x0078 | DEFE CSC Coefficient 02 Register                 |
| DEFE_CSC_COEF03_REG     | 0x007C | DEFE CSC Coefficient 03 Register                 |
| DEFE_CSC_COEF10_REG     | 0x0080 | DEFE CSC Coefficient 10 Register                 |
| DEFE_CSC_COEF11_REG     | 0x0084 | DEFE CSC Coefficient 11 Register                 |
| DEFE_CSC_COEF12_REG     | 0x0088 | DEFE CSC Coefficient 12 Register                 |
| DEFE_CSC_COEF13_REG     | 0x008C | DEFE CSC Coefficient 13 Register                 |
| DEFE_CSC_COEF20_REG     | 0x0090 | DEFE CSC Coefficient 20 Register                 |
| DEFE_CSC_COEF21_REG     | 0x0094 | DEFE CSC Coefficient 21 Register                 |
| DEFE_CSC_COEF22_REG     | 0x0098 | DEFE CSC Coefficient 22 Register                 |
| DEFE_CSC_COEF23_REG     | 0x009C | DEFE CSC Coefficient 23 Register                 |
| DEFE_WB_LINESTRD_EN_REG | 0x00D0 | DEFE Write Back Line Stride Enable Register      |
| DEFE_WB_LINESTRD0_REG   | 0x00D4 | DEFE Write Back Channel 3 Line Stride Register   |
| DEFE_CH0_INSIZE_REG     | 0x0100 | DEFE Channel 0 Input Size Register               |
| DEFE_CH0_OUTSIZE_REG    | 0x0104 | DEFE Channel 0 Output Size Register              |
| DEFE_CH0_HORZFACT_REG   | 0x0108 | DEFE Channel 0 Horizontal Factor Register        |
| DEFE_CH0_VERTFACT_REG   | 0x010C | DEFE Channel 0 Vertical factor Register          |
| DEFE_CH0_HORZPHASE_REG  | 0x0110 | DEFE Channel 0 Horizontal Initial Phase Register |
| DEFE_CH0_VERTPHASE0_REG | 0x0114 | DEFE Channel 0 Vertical Initial Phase 0 Register |
| DEFE_CH0_VERTPHASE1_REG | 0x0118 | DEFE Channel 0 Vertical Initial Phase 1 Register |

|                         |            |                                                              |
|-------------------------|------------|--------------------------------------------------------------|
| DEFE_CH1_INSIZE_REG     | 0x0200     | DEFE Channel 1 Input Size Register                           |
| DEFE_CH1_OUTSIZE_REG    | 0x0204     | DEFE Channel 1 Output Size Register                          |
| DEFE_CH1_HORZFACT_REG   | 0x0208     | DEFE Channel 1 Horizontal Factor Register                    |
| DEFE_CH1_VERTFACT_REG   | 0x020C     | DEFE Channel 1 Vertical factor Register                      |
| DEFE_CH1_HORZPHASE_REG  | 0x0210     | DEFE Channel 1 Horizontal Initial Phase Register             |
| DEFE_CH1_VERTPHASE0_REG | 0x0214     | DEFE Channel 1 Vertical Initial Phase 0 Register             |
| DEFE_CH1_VERTPHASE1_REG | 0x0218     | DEFE Channel 1 Vertical Initial Phase 1 Register             |
| DEFE_CH0_HORZCOEF_REGN  | 0x0400+N*4 | DEFE Channel 0 Horizontal Filter Coefficient Register N=0:31 |
| DEFE_CH0_VERTCOEF_REGN  | 0x0500+N*4 | DEFE Channel 0 Vertical Filter Coefficient Register N=0:31   |
| DEFE_CH1_HORZCOEF_REGN  | 0x0600+N*4 | DEFE Channel 1 Horizontal Filter Coefficient Register N=0:31 |
| DEFE_CH1_VERTCOEF_REGN  | 0x0700+N*4 | DEFE Channel 1 Vertical Filter Coefficient Register N=0:31   |

Note: Registers 0x0008~0x0218 except status registers are double buffered. when a new frame process starts and the buffered register configuration ready bit in frame process control register is set, the value of corresponding internal configuration register will be refreshed by this register, and programmers always can't read the value of corresponding internal register.

## 32.4. DEFE Register Description

### 32.4.1. DEFE\_EN\_REG

| Offset: 0x0 |                |                 | Register Name: DEFE_EN_REG                                                                                                                                                                                                                                                                                                                   |
|-------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                  |
| 31:1        | /              | /               | /                                                                                                                                                                                                                                                                                                                                            |
| 0           | R/W            | 0x0             | <p>EN<br/>DEFE enable<br/>0: Disable<br/>1: Enable</p> <p>When DEFE enable bit is disabled, the clock of DEFE module will be disabled.</p> <p>If this bit transits from 0 to 1, the frame process control register and the interrupt enable register will be initialized to default value, and the state machine of the module is reset.</p> |

### 32.4.2. DEFE\_FRM\_CTRL\_REG

| Offset: 0x4 |                |                 | Register Name: DEFE_FRM_CTRL_REG |
|-------------|----------------|-----------------|----------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                      |
| 31:24       | /              | /               | /                                |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23    | R/W | 0   | <b>COEF_ACCESS_CTRL</b><br>Fir coef ram access control<br>0: CPU doesn't access fir coef ram<br>1: CPU will access fir coef ram<br>This bit will be set to 1 before CPU accesses fir coef ram                                                                                                                                                                                                                                                                                                                                                     |
| 22:17 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16    | R/W | 0x0 | <b>FRM_START</b><br>Frame start & reset control<br>0: reset<br>1: start<br>If the bit is written to zero, the whole state machine and data paths of DEFE module will be reset.<br>When the bit is written to 1, DEFE will start a new frame process.                                                                                                                                                                                                                                                                                              |
| 15:12 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11    | R/W | 0x0 | <b>OUT_CTRL</b><br>DEFE output control<br>0: enable DEFE output to DEBE<br>1: disable DEFE output to DEBE<br>If DEFE write back function is enabled, DEFE output to DEBE isn't recommended.                                                                                                                                                                                                                                                                                                                                                       |
| 10:3  | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2     | R/W | 0x0 | <b>WB_EN</b><br>Write back enable<br>0: Disable<br>1: Enable<br>If output to DEBE is enabled, the writing back process will start when write back enable bit is set and a new frame processing begins. The bit will be self-cleared when writing-back frame process starts.                                                                                                                                                                                                                                                                       |
| 1     | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0     | R/W | 0x0 | <b>REG_RDY_EN</b><br>Register ready enable<br>0: not ready<br>1: registers configuration ready<br>Just as filter coefficients configuration, in order to ensure the display to be correct, the correlative display configuration registers are buffered too, and programmers also can change the value of correlative registers in any time. When the registers setting is finished, the programmer should set the bit if the new configuration is needed in next scaling frame.<br>When the new frame starts, the bit will also be self-cleared. |

### 32.4.3. DEFE\_BYPASS\_REG

|             |                                |
|-------------|--------------------------------|
| Offset: 0x8 | Register Name: DEFE_BYPASS_REG |
|-------------|--------------------------------|

| Bit   | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                               |
|-------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31: 2 | /              | /               | /                                                                                                                                                                                                                                                                         |
| 1     | R/W            | 0x0             | <p>CSC_BYPASS_EN<br/>CSC by-pass enable<br/>0: CSC enable<br/>1: CSC will be by-passed</p> <p>Actually, in order to ensure the module working to be correct, this bit only can be set when input data format is the same as output data format (both YUV or both RGB)</p> |
| 0     | /              | /               | /                                                                                                                                                                                                                                                                         |

#### 32.4.4. DEFE\_AGTH\_SEL\_REG

| Offset: 0xC |                |                 | Register Name: DEFE_AGTH_SEL_REG                                                                                 |
|-------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit         | Read/W<br>rite | Default/<br>Hex | Description                                                                                                      |
| 31:9        | /              | /               | /                                                                                                                |
| 8           | R/W            | 0x0             | <p>LINEBUF_AGTH<br/>DEFE line buffer algorithm select<br/>0: horizontal filtered result<br/>1: original data</p> |
| 7:0         | /              | /               | /                                                                                                                |

#### 32.4.5. DEFE\_LINT\_CTRL\_REG

| Offset: 0x10 |                |                 | Register Name: DEFE_LINT_CTRL_REG                                                              |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                    |
| 31:28        | /              | /               | /                                                                                              |
| 27:16        | R              | 0x0             | CURRENT_LINE                                                                                   |
| 15           | R/W            | 0x0             | <p>FIELD_SEL<br/>Field select<br/>0: each field<br/>1: end field(field counter in reg0x2c)</p> |
| 14:13        | /              | /               | /                                                                                              |
| 12:0         | R/W            | 0x0             | TRIG_LINE<br>Trigger line number of line interrupt                                             |

#### 32.4.6. DEFE\_BUF\_ADDR0\_REG

| Offset: 0x20 |                |                 | Register Name: DEFE_BUF_ADDR0_REG |
|--------------|----------------|-----------------|-----------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                       |
| 31:0         | R/W            | 0x0             | BUF_ADDR                          |

|  |  |  |                                                                                                                                                                                                                                                            |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>DEFE frame buffer address</p> <p>In tile-based type:</p> <p>The address is the start address of the line in the first tile used to generate output frame.</p> <p>In non-tile-based type:</p> <p>The address is the start address of the first line.</p> |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

### 32.4.7. DEFE\_BUF\_ADDR1\_REG

| Offset: 0x24 |                |                 | Register Name: DEFE_BUF_ADDR1_REG                                                                                                                                                                                                                                          |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                |
| 31:0         | R/W            | 0x0             | <p>BUF_ADDR</p> <p>DEFE frame buffer address</p> <p>In tile-based type:</p> <p>The address is the start address of the line in the first tile used to generate output frame.</p> <p>In non-tile-based type:</p> <p>The address is the start address of the first line.</p> |

### 32.4.8. DEFE\_BUF\_ADDR2\_REG

| Offset: 0x28 |                |                 | Register Name: DEFE_BUF_ADDR2_REG                                                                                                                                                                                                                                          |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                |
| 31:0         | R/W            | 0x0             | <p>BUF_ADDR</p> <p>DEFE frame buffer address</p> <p>In tile-based type:</p> <p>The address is the start address of the line in the first tile used to generate output frame.</p> <p>In non-tile-based type:</p> <p>The address is the start address of the first line.</p> |

### 32.4.9. DEFE\_FIELD\_CTRL\_REG

| Offset: 0x2C |                |                 | Register Name: DEFE_FIELD_CTRL_REG                                                             |
|--------------|----------------|-----------------|------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                    |
| 31:13        | /              | /               | /                                                                                              |
| 12           | R/W            | 0x0             | <p>FIELD_LOOP_MOD</p> <p>Field loop mode</p> <p>0: the last field; 1: the full frame</p>       |
| 11           | /              | /               | /                                                                                              |
| 10:8         | R/W            | 0x0             | <p>VALID_FIELD_CNT</p> <p>Valid field counter bit</p> <p>the valid value = this value + 1;</p> |

|     |     |     |                                                                                                  |
|-----|-----|-----|--------------------------------------------------------------------------------------------------|
| 7:0 | R/W | 0x0 | FIELD_CNT<br>Field counter<br>each bit specify a field to display, 0: top field, 1: bottom field |
|-----|-----|-----|--------------------------------------------------------------------------------------------------|

### 32.4.10. DEFE\_TB\_OFF0\_REG

| Offset: 0x30 |                |                 | Register Name: DEFE_TB_OFF0_REG                                     |
|--------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                         |
| 31:21        | /              | /               | /                                                                   |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the end tile |
| 15:13        | /              | /               | /                                                                   |
| 12:8         | R/W            | 0x0             | Y_OFFSET0<br>The y offset of the top-left point in the first tile   |
| 7:5          | /              | /               | /                                                                   |
| 4:0          | R/W            | 0x0             | X_OFFSET0<br>The x offset of the top-left point in the first tile   |

### 32.4.11. DEFE\_TB\_OFF1\_REG

| Offset: 0x34 |                |                 | Register Name: DEFE_TB_OFF1_REG                                     |
|--------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                         |
| 31:21        | /              | /               | /                                                                   |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the end tile |
| 15:13        | /              | /               | /                                                                   |
| 12:8         | R/W            | 0x0             | Y_OFFSET0<br>The y offset of the top-left point in the first tile   |
| 7:5          | /              | /               | /                                                                   |
| 4:0          | R/W            | 0x0             | X_OFFSET0<br>The x offset of the top-left point in the first tile   |

### 32.4.12. DEFE\_TB\_OFF2\_REG

| Offset: 0x38 |                |                 | Register Name: DEFE_TB_OFF2_REG                                     |
|--------------|----------------|-----------------|---------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                         |
| 31:21        | /              | /               | /                                                                   |
| 20:16        | R/W            | 0x0             | X_OFFSET1<br>The x offset of the bottom-right point in the end tile |
| 15:13        | /              | /               | /                                                                   |
| 12:8         | R/W            | 0x0             | Y_OFFSET0<br>The y offset of the top-left point in the first tile   |

|     |     |     |                                                                   |
|-----|-----|-----|-------------------------------------------------------------------|
| 7:5 | /   | /   | /                                                                 |
| 4:0 | R/W | 0x0 | X_OFFSET0<br>The x offset of the top-left point in the first tile |

### 32.4.13. DEFE\_LINESTRD0\_REG

| Offset: 0x40 |                |                 | Register Name: DEFE_LINESTRD0_REG                                                                                                                                                                                                                                                                                               |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                     |
| 31:0         | R/W            | 0x0             | LINE_STRIDE<br>In tile-based type<br>The stride length is the distance from the start of the end line in one tile to the start of the first line in next tile(here next tile is in vertical direction)<br>In non-tile-based type<br>The stride length is the distance from the start of one line to the start of the next line. |

### 32.4.14. DEFE\_LINESTRD1\_REG

| Offset: 0x44 |                |                 | Register Name: DEFE_LINESTRD1_REG                                                                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 31:0         | R/W            | 0x0             | LINE_STRIDE<br>In tile-based type<br>The stride length is the distance from the start of the end line in one tile to the start of the first line in next tile(here next tile is in vertical direction)<br>In non- tile-based type<br>The stride length is the distance from the start of one line to the start of the next line. |

### 32.4.15. DEFE\_LINESTRD2\_REG

| Offset: 0x48 |                |                 | Register Name: DEFE_LINESTRD2_REG                                                                                                                                                                                                                                                                                                |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                      |
| 31:0         | R/W            | 0x0             | LINE_STRIDE<br>In tile-based type<br>The stride length is the distance from the start of the end line in one tile to the start of the first line in next tile(here next tile is in vertical direction)<br>In non- tile-based type<br>The stride length is the distance from the start of one line to the start of the next line. |

### **32.4.16. DEFE\_INPUT\_FMT\_REG**

| Offset: 0x4C |                |                 | Register Name: DEFE_INPUT_FMT_REG                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:17        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16           | R/W            | 0x0             | BYTE_SEQ<br>Input data byte sequence selection<br>0: P3P2P1P0(word)<br>1: P0P1P2P3(word)                                                                                                                                                                                                                                                                                                                             |
| 15:13        | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12           | R/W            | 0x0             | SCAN_MOD<br>Scanning Mode selection<br>0: non-interlace<br>1: interlace                                                                                                                                                                                                                                                                                                                                              |
| 11           | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10:8         | R/W            | 0x0             | DATA_MOD<br>Input data mode selection<br>000: non-tile-based planar data<br>001: interleaved data<br>010: non-tile-based UV combined data<br>100: tile-based planar data<br>110: tile-based UV combined data<br>other: reserved                                                                                                                                                                                      |
| 7            | /              | /               | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6:4          | R/W            | 0x0             | DATA_FMT<br>Input component data format<br>In non-tile-based planar data mode:<br>000: YUV 4:4:4<br>001: YUV 4:2:2<br>010: YUV 4:2:0<br>011: YUV 4:1:1<br>100: CSI RGB data<br>101: RGB888<br>Other: Reserved<br>In interleaved data mode:<br>000: YUV 4:4:4<br>001: YUV 4:2:2<br>101: ARGB8888<br>Other: reserved<br>In non-tile-based UV combined data mode:<br>001: YUV 4:2:2<br>010: YUV 4:2:0<br>011: YUV 4:1:1 |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | Other: reserved<br><br>In tile-based planar data mode:<br>001: YUV 4:2:2<br>010: YUV 4:2:0<br>011: YUV 4:1:1<br>Other: Reserved<br><br>In tile-based UV combined data mode:<br>001: YUV 4:2:2<br>010: YUV 4:2:0<br>011: YUV 4:1:1<br>Other: reserved                                                                                                                                                             |
| 3:2 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1:0 | R/W | 0x0 | DATA_PS<br><br>Pixel sequence<br><br>In interleaved YUV422 data mode:<br>00: Y1V0Y0U0<br>01: V0Y1U0Y0<br>10: Y1U0Y0V0<br>11: U0Y1V0Y0<br><br>In interleaved YUV444 data mode:<br>00: VUYA<br>01: AYUV<br>Other: reserved<br><br>In UV combined data mode: (UV component)<br>00: V1U1V0U0<br>01: U1V1U0V0<br>Other: reserved<br><br>In interleaved ARGB8888 data mode:<br>00: BGRA<br>01: ARGB<br>Other: reserved |

### 32.4.17. DEFE\_WB\_ADDR0\_REG

| Offset: 0x50 |                |                 | Register Name: DEFE_WB_ADDR0_REG                       |
|--------------|----------------|-----------------|--------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                            |
| 31:0         | R/W            | 0x0             | WB_ADDR<br>Write-back address setting for scaled data. |

### 32.4.18. DEFE\_OUTPUT\_FMT\_REG

| Offset: 0x5C |                |                 | Register Name: DEFE_OUTPUT_FMT_REG |
|--------------|----------------|-----------------|------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                        |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 17:16 | R/W | 0   | WB_Ch_Sel<br>Write back channel select(chsel)<br>0/1: Ch3<br>2: Ch4<br>3: Ch5<br>Other: reserved                                                                                                                                                                                                                                                                                                                                                             |
| 15:9  | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 8     | R/W | 0x0 | BYTE_SEQ<br>Output data byte sequence selection<br>0: P3P2P1P0(word)<br>1: P0P1P2P3(word)<br>For ARGB, when this bit is 0, the byte sequence is BGRA, and when this bit is 1, the byte sequence is ARGB;                                                                                                                                                                                                                                                     |
| 7:5   | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4     | R/W | 0x0 | SCAN_MOD<br>Output interlace enable<br>0: disable<br>1: enable<br>When output interlace enable, scaler selects YUV initial phase according to LCD field signal                                                                                                                                                                                                                                                                                               |
| 3     | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2:0   | R/W | 0x0 | DATA_FMT<br>Data format<br>000: planar RGB888 conversion data format<br>001: interleaved BGRA8888 conversion data format(A component always be pad 0xff)<br>010: interleaved ARGB8888 conversion data format(A component always be pad 0xff)<br>100: planar YUV 444<br>101: planar YUV 420(only support YUV input and not interleaved mode)<br>110: planar YUV 422(only support YUV input)<br>111: planar YUV 411(only support YUV input)<br>Other: reserved |

### 32.4.19. DEFE\_INT\_EN\_REG

| Offset: 0x60 |                | Register Name: DEFE_INT_EN_REG |                                                     |
|--------------|----------------|--------------------------------|-----------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex                | Description                                         |
| 31:11        | /              | /                              | /                                                   |
| 10           | R/W            | 0x0                            | REG_LOAD_EN<br>Register ready load interrupt enable |

|     |     |     |                                                                     |
|-----|-----|-----|---------------------------------------------------------------------|
| 9   | R/W | 0x0 | LINE_EN<br>Line interrupt enable                                    |
| 8   | /   | /   | /                                                                   |
| 7   | R/W | 0x0 | WB_EN<br>Write-back end interrupt enable<br>0: Disable<br>1: Enable |
| 6:0 | /   | /   | /                                                                   |

### 32.4.20. DEFE\_INT\_STATUS\_REG

| Offset: 0x64 |                |                 | Register Name: DEFE_INT_STATUS_REG                      |
|--------------|----------------|-----------------|---------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                             |
| 31:11        | /              | /               | /                                                       |
| 10           | R/W            | 0x0             | REG_LOAD_STATUS<br>Register ready load interrupt status |
| 9            | R/W            | 0x0             | LINE_STATUS<br>Line interrupt status                    |
| 8            | /              | /               | /                                                       |
| 7            | R/W            | 0x0             | WB_STATUS<br>Write-back end interrupt status            |
| 6:0          | /              | /               | /                                                       |

### 32.4.21. DEFE\_STATUS\_REG

| Offset: 0x68 |                |                 | Register Name: DEFE_STATUS_REG                                                                                                                                                  |
|--------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                     |
| 31:29        | /              | /               | /                                                                                                                                                                               |
| 28:16        | R              | 0x0             | LINE_ON_SYNC<br>Line number(when sync reached)                                                                                                                                  |
| 15           | R/W            | 0x0             | WB_ERR_SYNC<br>Sync reach flag when capture in process                                                                                                                          |
| 14           | R/W            | 0x0             | WB_ERR_LOSEDATA<br>Lose data flag when capture in process                                                                                                                       |
| 13           | /              | /               | /                                                                                                                                                                               |
| 12           | R              | 0x0             | WB_ERR_STATUS<br>write-back error status<br>0: valid write back<br>1: un-valid write back<br>This bit is cleared through writing 0 to reset/start bit in frame control register |
| 11           | R              | 0x0             | COEF_ACCESS_STATUS                                                                                                                                                              |

|      |   |     |                                                                                                                                                                                                                                                                                                  |
|------|---|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |   |     | Fir coef access status<br>0: scaler module can access fir coef RAM<br>1: CPU can access fir coef ram<br>This bit must be 1 before CPU accesses fir coef RAM. When this bit is 1, scaler module will fetch 0x00004000 from RAM.                                                                   |
| 10:6 | / | /   | /                                                                                                                                                                                                                                                                                                |
| 5    | R | 0x0 | LCD_FIELD<br>LCD field status<br>0: top field<br>1: bottom field                                                                                                                                                                                                                                 |
| 4    | R | 0x0 | DRAM_STATUS<br>Access dram status<br>0: idle<br>1: busy<br>This flag indicates whether DEFE is accessing dram                                                                                                                                                                                    |
| 3    | / | /   | /                                                                                                                                                                                                                                                                                                |
| 2    | R | 0x0 | CFG_PENDING<br>Register configuration pending<br>0: no pending<br>1: configuration pending<br>This bit indicates the registers for the next frame has been configured.<br>This bit will be set when configuration ready bit is set and this bit will be cleared when a new frame process begins. |
| 1    | R | 0x0 | WB_STATUS<br>Write-back process status<br>0: write-back end or write-back disable<br>1: write-back in process<br>This flag indicates that a full frame has not been written back to memory. The bit will be set when write-back enable bit is set, and be cleared when write-back process ends.  |
| 0    | R | 0x0 | FRM_BUSY<br>Frame busy.<br>This flag indicates that the frame is being processed.<br>The bit will be set when frame process reset & start is set, and be cleared when frame process is reset or disabled.                                                                                        |

### 32.4.22. DEFE\_CSC\_COEF00\_REG

| Offset: 0x70 |                | Register Name: DEFE_CSC_COEF00_REG |                             |
|--------------|----------------|------------------------------------|-----------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex                    | Description                 |
| 31:13        | /              | /                                  | /                           |
| 12:0         | R/W            | 0x0                                | COEF<br>the Y/G coefficient |

|  |  |  |                                           |
|--|--|--|-------------------------------------------|
|  |  |  | the value equals to coefficient* $2^{10}$ |
|--|--|--|-------------------------------------------|

### 32.4.23. DEFE\_CSC\_COEF01\_REG

| Offset: 0x74 |                |                 | Register Name: DEFE_CSC_COEF01_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.24. DEFE\_CSC\_COEF02\_REG

| Offset: 0x78 |                |                 | Register Name: DEFE_CSC_COEF02_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.25. DEFE\_CSC\_COEF03\_REG

| Offset: 0x7C |                |                 | Register Name: DEFE_CSC_COEF03_REG                                 |
|--------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 31:14        | /              | /               | /                                                                  |
| 13:0         | R/W            | 0x0             | CONT<br>the Y/G constant<br>the value equals to coefficient* $2^4$ |

### 32.4.26. DEFE\_CSC\_COEF10\_REG

| Offset: 0x80 |                |                 | Register Name: DEFE_CSC_COEF10_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.27. DEFE\_CSC\_COEF11\_REG

| Offset: 0x84 |                |                 | Register Name: DEFE_CSC_COEF11_REG |
|--------------|----------------|-----------------|------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                        |

|       |     |     |                                                                          |
|-------|-----|-----|--------------------------------------------------------------------------|
| 31:13 | /   | /   | /                                                                        |
| 12:0  | R/W | 0x0 | COEF<br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.28. DEFE\_CSC\_COEF12\_REG

| Offset: 0x88 |                |                 | Register Name: DEFE_CSC_COEF12_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.29. DEFE\_CSC\_COEF13\_REG

| Offset: 0x8C |                |                 | Register Name: DEFE_CSC_COEF13_REG                                 |
|--------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 31:14        | /              | /               | /                                                                  |
| 13:00        | R/W            | 0x0             | CONT<br>the U/R constant<br>the value equals to coefficient* $2^4$ |

### 32.4.30. DEFE\_CSC\_COEF20\_REG

| Offset: 0x90 |                |                 | Register Name: DEFE_CSC_COEF20_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the V/B coefficient<br>the value equals to coefficient* $2^{10}$ |

### 32.4.31. DEFE\_CSC\_COEF21\_REG

| Offset: 0x94 |                |                 | Register Name: DEFE_CSC_COEF21_REG                                       |
|--------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                              |
| 31:13        | /              | /               | /                                                                        |
| 12:0         | R/W            | 0x0             | COEF<br>the V/B coefficient<br>the value equals to coefficient* $2^{10}$ |

### **32.4.32. DEFE\_CSC\_COEF22\_REG**

| Offset: 0x98 |                |                 | Register Name: DEFE_CSC_COEF22_REG                                             |
|--------------|----------------|-----------------|--------------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                    |
| 31:13        | /              | /               | /                                                                              |
| 12:0         | R/W            | 0x0             | COEF<br>the V/B coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

### **32.4.33. DEFE\_CSC\_COEF23\_REG**

| Offset: 0x9C |                |                 | Register Name: DEFE_CSC_COEF23_REG                                         |
|--------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                                |
| 31:14        | /              | /               | /                                                                          |
| 13:00        | R/W            | 0x0             | CONT<br>the V/B constant<br>the value equals to coefficient*2 <sup>4</sup> |

### **32.4.34. DEFE\_WB\_LINESTRD\_EN\_REG**

| Offset: 0xD0 |                |                 | Register Name: DEFE_WB_LINESTRD_EN_REG                         |
|--------------|----------------|-----------------|----------------------------------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                                                    |
| 31:1         | /              | /               | /                                                              |
| 0            | R/W            | 0x0             | EN<br>Write back line-stride enable<br>0: disable<br>1: enable |

### **32.4.35. DEFE\_WB\_LINESTRD0\_REG**

| Offset: 0xD4 |                |                 | Register Name: DEFE_WB_LINESTRD0_REG    |
|--------------|----------------|-----------------|-----------------------------------------|
| Bit          | Read/W<br>rite | Default/<br>Hex | Description                             |
| 31:0         | R/W            | 0x0             | LINE_STRD<br>Ch3 write back line-stride |

### **32.4.36. DEFE\_CH0\_INSIZE\_REG**

| Offset: 0x100 |                |                 | Register Name: DEFE_CH0_INSIZE_REG            |
|---------------|----------------|-----------------|-----------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                   |
| 31:29         | /              | /               | /                                             |
| 28:16         | R/W            | 0x0             | IN_HEIGHT<br>Input image Y/G component height |

|       |     |     |                                                                                                                                                                                  |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | Input image height = The value of these bits add 1                                                                                                                               |
| 15:13 | /   | /   | /                                                                                                                                                                                |
| 12:0  | R/W | 0x0 | IN_WIDTH<br>Input image Y/G component width<br>The image width = The value of these bits add 1<br>When line buffer result selection is original data, the maximum width is 2048. |

### 32.4.37. DEFE\_CH0\_OUTSIZE\_REG

| Offset: 0x104 |                |                 | Register Name: DEFE_CH0_OUTSIZE_REG                                                                                                                                                                   |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                           |
| 31:29         | /              | /               | /                                                                                                                                                                                                     |
| 28:16         | R/W            | 0x0             | OUT_HEIGHT<br>Output layer Y/G component height<br>The output layer height = The value of these bits add 1                                                                                            |
| 15:13         | /              | /               | /                                                                                                                                                                                                     |
| 12:0          | R/W            | 0x0             | OUT_WIDTH<br>Output layer Y/G component width<br>The output layer width = The value of these bits add 1<br>When line buffer result selection is horizontal filtered result, the maximum width is 2048 |

### 32.4.38. DEFE\_CH0\_HORZFACT\_REG

| Offset: 0x108 |                |                 | Register Name: DEFE_CH0_HORZFACT_REG                                                                                          |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                   |
| 31:24         | /              | /               | /                                                                                                                             |
| 23:16         | R/W            | 0x0             | FACTOR_INT<br>The integer part of the horizontal scaling ratio<br>the horizontal scaling ratio = input width/output width     |
| 15:0          | R/W            | 0x0             | FACTOR_FRAC<br>The fractional part of the horizontal scaling ratio<br>the horizontal scaling ratio = input width/output width |

### 32.4.39. DEFE\_CH0\_VERTFACT\_REG

| Offset: 0x10C |                |                 | Register Name: DEFE_CH0_VERTFACT_REG                         |
|---------------|----------------|-----------------|--------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31:24         | /              | /               | /                                                            |
| 23:16         | R/W            | 0x0             | FACTOR_INT<br>The integer part of the vertical scaling ratio |

|      |     |     |                                                                                                                              |
|------|-----|-----|------------------------------------------------------------------------------------------------------------------------------|
|      |     |     | the vertical scaling ratio = input height/output height                                                                      |
| 15:0 | R/W | 0x0 | FACTOR_FRAC<br>The fractional part of the vertical scaling ratio<br>the vertical scaling ratio = input height /output height |

#### 32.4.40. DEFE\_CH0\_HORZPHASE\_REG

| Offset: 0x110 |                |                 | Register Name: DEFE_CH0_HORZPHASE_REG                                                                            |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                      |
| 31:20         | /              | /               | /                                                                                                                |
| 19:0          | R/W            | 0x0             | PHASE<br>Y/G component initial phase in horizontal (complement)<br>This value equals to initial phase * $2^{16}$ |

#### 32.4.41. DEFE\_CH0\_VERTPHASE0\_REG

| Offset: 0x114 |                |                 | Register Name: DEFE_CH0_VERTPHASE0_REG                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                  |
| 31:20         | /              | /               | /                                                                                                                            |
| 19:0          | R/W            | 0x0             | PHASE<br>Y/G component initial phase in vertical for top field (complement)<br>This value equals to initial phase * $2^{16}$ |

#### 32.4.42. DEFE\_CH0\_VERTPHASE1\_REG

| Offset: 0x118 |                |                 | Register Name: DEFE_CH0_VERTPHASE1_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                     |
| 31:20         | /              | /               | /                                                                                                                               |
| 19:0          | R/W            | 0x0             | PHASE<br>Y/G component initial phase in vertical for bottom field (complement)<br>This value equals to initial phase * $2^{16}$ |

#### 32.4.43. DEFE\_CH1\_INSIZE\_REG

| Offset: 0x200 |                |                 | Register Name: DEFE_CH1_INSIZE_REG                                                                  |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                         |
| 31:29         | /              | /               | /                                                                                                   |
| 28:16         | R/W            | 0x0             | IN_HEIGHT<br>Input image U/R component height<br>Input image height = The value of these bits add 1 |
| 15:13         | /              | /               | /                                                                                                   |
| 12:0          | R/W            | 0x0             | IN_WIDTH                                                                                            |

|  |  |  |                                                                                                                                                                                                |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | <p>Input image U/R component width<br/>         The image width = The value of these bits add 1<br/>         When line buffer result selection is original data, the maximum width is 2048</p> |
|--|--|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### **32.4.44. DEFE\_CH1\_OUTSIZE\_REG**

| Offset: 0x204 |                |                 | Register Name: DEFE_CH1_OUTSIZE_REG                                                                                                                                                                                                        |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                                                                |
| 31:29         | /              | /               | /                                                                                                                                                                                                                                          |
| 28:16         | R/W            | 0x0             | <p>OUT_HEIGHT<br/>         Output layer U/R component height<br/>         The output layer height = The value of these bits add 1</p>                                                                                                      |
| 15:13         | /              | /               | /                                                                                                                                                                                                                                          |
| 12:0          | R/W            | 0x0             | <p>OUT_WIDTH<br/>         Output layer U/R component width<br/>         The output layer width = The value of these bits add 1<br/>         When line buffer result selection is horizontal filtered result, the maximum width is 2048</p> |

#### **32.4.45. DEFE\_CH1\_HORZFACT\_REG**

| Offset: 0x208 |                |                 | Register Name: DEFE_CH1_HORZFACT_REG                                                                                                                     |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                              |
| 31:24         | /              | /               | /                                                                                                                                                        |
| 23:16         | R/W            | 0x0             | <p>FACTOR_INT<br/>         The integer part of the horizontal scaling ratio<br/>         the horizontal scaling ratio = input width/output width</p>     |
| 15:0          | R/W            | 0x0             | <p>FACTOR_FRAC<br/>         The fractional part of the horizontal scaling ratio<br/>         the horizontal scaling ratio = input width/output width</p> |

#### **32.4.46. DEFE\_CH1\_VERTFACT\_REG**

| Offset: 0x20C |                |                 | Register Name: DEFE_CH1_VERTFACT_REG                                                                                                                    |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                             |
| 31:24         | /              | /               | /                                                                                                                                                       |
| 23:16         | R/W            | 0x0             | <p>FACTOR_INT<br/>         The integer part of the vertical scaling ratio<br/>         the vertical scaling ratio = input height/output height</p>      |
| 15:0          | R/W            | 0x0             | <p>FACTOR_FRAC<br/>         The fractional part of the vertical scaling ratio<br/>         the vertical scaling ratio = input height /output height</p> |

#### **32.4.47. DEFE\_CH1\_HORZPHASE\_REG**

| Offset: 0x210 |                |                 | Register Name: DEFE_CH1_HORZPHASE_REG                                                                            |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                      |
| 31:20         | /              | /               | /                                                                                                                |
| 19:0          | R/W            | 0x0             | PHASE<br>U/R component initial phase in horizontal (complement)<br>This value equals to initial phase * $2^{16}$ |

#### **32.4.48. DEFE\_CH1\_VERTPHASE0\_REG**

| Offset: 0x214 |                |                 | Register Name: DEFE_CH1_VERTPHASE0_REG                                                                                       |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                  |
| 31:20         | /              | /               | /                                                                                                                            |
| 19:0          | R/W            | 0x0             | PHASE<br>U/R component initial phase in vertical for top field (complement)<br>This value equals to initial phase * $2^{16}$ |

#### **32.4.49. DEFE\_CH1\_VERTPHASE1\_REG**

| Offset: 0x218 |                |                 | Register Name: DEFE_CH1_VERTPHASE1_REG                                                                                          |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                     |
| 31:20         | /              | /               | /                                                                                                                               |
| 19:0          | R/W            | 0x0             | PHASE<br>U/R component initial phase in vertical for bottom field (complement)<br>This value equals to initial phase * $2^{16}$ |

#### **32.4.50. DEFE\_CH0\_HORZCOEF0\_REGN (N=0:31)**

| Offset: 0x400+N*4 |                |                 | Register Name: DEFE_CH0_HORZCOEF0_REGN                                        |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------|
| Bit               | Read/W<br>rite | Default/<br>Hex | Description                                                                   |
| 31:24             | R/W            | 0x0             | TAP3<br>Horizontal tap3 coefficient<br>The value equals to coefficient* $2^6$ |
| 23:16             | R/W            | 0x0             | TAP2<br>Horizontal tap2 coefficient<br>The value equals to coefficient* $2^6$ |
| 15:8              | R/W            | 0x0             | TAP1<br>Horizontal tap1 coefficient<br>The value equals to coefficient* $2^6$ |
| 7:0               | R/W            | 0x0             | TAP0                                                                          |

|  |  |  |                                                                               |
|--|--|--|-------------------------------------------------------------------------------|
|  |  |  | Horizontal tap0 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
|--|--|--|-------------------------------------------------------------------------------|

### 32.4.51. DEFE\_CH0\_VERTCOEF\_REGN (N=0:31)

| Offset: 0x500+N*4 |                |                 | Register Name: DEFE_CH0_VERTCOEF_REGN                                               |
|-------------------|----------------|-----------------|-------------------------------------------------------------------------------------|
| Bit               | Read/W<br>rite | Default/<br>Hex | Description                                                                         |
| 31:24             | R/W            | 0x0             | TAP3<br>Vertical tap3 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 23:16             | R/W            | 0x0             | TAP2<br>Vertical tap2 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 15:8              | R/W            | 0x0             | TAP1<br>Vertical tap1 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 7:0               | R/W            | 0x0             | TAP0<br>Vertical tap0 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |

### 32.4.52. DEFE\_CH1\_HORZCOEF0\_REGN (N=0 :31)

| Offset: 0x600+N*4 |                |                 | Register Name: DEFE_CH1_HORZCOEF0_REGN                                                |
|-------------------|----------------|-----------------|---------------------------------------------------------------------------------------|
| Bit               | Read/W<br>rite | Default/<br>Hex | Description                                                                           |
| 31:24             | R/W            | 0x0             | TAP3<br>Horizontal tap3 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 23:16             | R/W            | 0x0             | TAP2<br>Horizontal tap2 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 15:8              | R/W            | 0x0             | TAP1<br>Horizontal tap1 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 7:0               | R/W            | 0x0             | TAP0<br>Horizontal tap0 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |

### 32.4.53. DEFE\_CH1\_VERTCOEF\_REGN (N=0 :31)

| Offset: 0x700+N*4 |                |                 | Register Name: DEFE_CH1_VERTCOEF_REGN |
|-------------------|----------------|-----------------|---------------------------------------|
| Bit               | Read/W<br>rite | Default/<br>Hex | Description                           |
| 31:24             | R/W            | 0x0             | TAP3<br>Vertical tap3 coefficient     |

|       |     |     |                                                                                     |
|-------|-----|-----|-------------------------------------------------------------------------------------|
|       |     |     | The value equals to coefficient*2 <sup>6</sup>                                      |
| 23:16 | R/W | 0x0 | TAP2<br>Vertical tap2 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 15:8  | R/W | 0x0 | TAP1<br>Vertical tap1 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |
| 7:0   | R/W | 0x0 | TAP0<br>Vertical tap0 coefficient<br>The value equals to coefficient*2 <sup>6</sup> |

## 33. Display Engine Back End

### 33.1. Overview

The Display Engine Back End (DEBE) features:

- 4 moveable & size-adjustable layers
- Layer size up to 8192\*8192 pixels
- Support Alpha blending
- Support color key
- Support write back function
- Support 1/2/4/8 bpp mono / palette
- Support 16/24/32 bpp color (external frame buffer)
  - ----5/6/5
  - ----1/5/5/5
  - ----0/8/8/8
  - ----8/8/8
  - ----8/8/8/8
  - ----4/4/4/4
- Support on-chip SRAM
  - ----256 entry 32-bpp palette
  - ----1/2/4/8 bpp internal frame buffer
  - ---- support Gamma correction
- Support hardware cursor
  - ----32\*32 @8-bpp
  - ----64\*64 @2-bpp
  - ----64\*32 @4-bpp
  - ----32\*64 @4-bpp
- Support YUV input channel
- Output color correction

### 33.2. DEBE Block Diagram



Figure 33-1 Display Engine Block Diagram

### 33.3. DEBE Register list

| Module name | Base address |
|-------------|--------------|
| DEBE        | 0x01e60000   |

| Register name         | Offset        | Description                                       |
|-----------------------|---------------|---------------------------------------------------|
| DEBE_MODCTL_REG       | 0x800         | DEBE mode control register                        |
| DEBE_BACKCOLOR_REG    | 0x804         | DE-back color control register                    |
| DEBE_DISSIZE_REG      | 0x808         | DE-back display size setting register             |
| DEBE_LAYSIZE_REG      | 0x810 – 0x81C | DE-layer size register                            |
| DEBE_LAYCOOR_REG      | 0x820 – 0x82C | DE-layer coordinate control register              |
| DEBE_LAYLINEWIDTH_REG | 0x840 – 0x84C | DE-layer frame buffer line width register         |
| DEBE_LAYFB_L32ADD_REG | 0x850 – 0x85C | DE-layer frame buffer low 32 bit address register |
| DEBE_LAYFB_H4ADD_REG  | 0x860         | DE-layer frame buffer high 4 bit address register |
| DEBE_REGBUFFCTL_REG   | 0x870         | DE-Register buffer control register               |
| DEBE_CKMAX_REG        | 0x880         | DE-color key MAX register                         |
| DEBE_CKMIN_REG        | 0x884         | DE-color key MIN register                         |
| DEBE_CKCFG_REG        | 0x888         | DE-color key configuration register               |
| DEBE_ATTCTL_REG0      | 0x890 – 0x89C | DE-layer attribute control register0              |
| DEBE_ATTCTL_REG1      | 0x8A0 – 0x8AC | DE-layer attribute control register1              |

|                        |               |                                                |
|------------------------|---------------|------------------------------------------------|
| DEBE_HWCCTL_REG        | 0x8D8         | DE-HWC coordinate control register             |
| DEBE_HWCFBCTL_REG      | 0x8E0         | DE-HWC frame buffer format register            |
| DEBE_WBCTL_REG         | 0x8F0         | DEBE write back control register               |
| DEBE_WBADD_REG         | 0x8F4         | DEBE write back address register               |
| DEBE_WBLINWIDTH_REG    | 0x8F8         | DEBE write back buffer line width register     |
| DEBE_IYUVCTL_REG       | 0x920         | DEBE input YUV channel control register        |
| DEBE_IYUVADD_REG       | 0x930 – 0x938 | DEBE YUV channel frame buffer address register |
| DEBE_IYUVLINEWIDTH_REG | 0x940 – 0x948 | DEBE YUV channel buffer line width register    |
| DEBE_YGCOEF_REG        | 0x950 – 0x958 | DEBE Y/G coefficient register                  |
| DEBE_YGCONS_REG        | 0x95C         | DEBE Y/G constant register                     |
| DEBE_URCOEF_REG        | 0x960 – 0x968 | DEBE U/R coefficient register                  |
| DEBE_URCONS_REG        | 0x96C         | DEBE U/R constant register                     |
| DEBE_VBCOEF_REG        | 0x970 – 0x978 | DEBE V/B coefficient register                  |
| DEBE_VBCONS_REG        | 0x97C         | DEBE V/B constant register                     |
| DEBE_OCCTL_REG         | 0x9C0         | DEBE output color control register             |
| DEBE_OCRCOEF_REG       | 0x9D0-0x9D8   | DEBE output color R coefficient register       |
| DEBE_OCRCONS_REG       | 0x9DC         | DEBE output color R constant register          |
| DEBE_OCGCOEF_REG       | 0x9E0-0x9E8   | DEBE output color G coefficient register       |
| DEBE_OCGCONS_REG       | 0x9EC         | DEBE output color G constant register          |
| DEBE_OCBCOEF_REG       | 0x9F0-0x9F8   | DEBE output color B coefficient register       |
| DEBE_OCBCONS_REG       | 0x9FC         | DEBE output color B constant register          |
| /                      | Memories      | /                                              |
| /                      | 0x4400-0x47FF | Gamma table                                    |
|                        | 0x4800-0x4BFF | DE-HWC pattern memory block                    |
|                        | 0x4C00-0x4FFF | DE-HWC color palette table                     |
|                        | 0x5000-0x53FF | Pipe0 palette table                            |
|                        | 0x5400-0x57FF | Pipe1 palette table                            |

## 33.4. DEBE Register Description

### 33.4.1. DEBE Mode Control Register

| Offset: 0x800 |             |              | Register Name: DEBE_MODCTL_REG                                |
|---------------|-------------|--------------|---------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                   |
| 31:30         | /           | /            | /                                                             |
| 29            | R/W         | 0            | LINE_SEL<br>Start top/bottom line selection in interlace mode |
| 28            | R/W         | 0            | ITLMOUD_EN                                                    |

|       |     |   |                                                                                                                                                                                                |
|-------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | Interlace mode enable<br>0:disable<br>1:enable                                                                                                                                                 |
| 27:17 | /   | / | /                                                                                                                                                                                              |
| 16    | R/W | 0 | HWC_EN<br>Hardware cursor enabled/disabled control<br>0: Disabled<br>1: Enabled<br>Hardware cursor has the highest priority, in the alpha blender0, the alpha value of cursor will be selected |
| 15:12 | /   | / | /                                                                                                                                                                                              |
| 11    | R/W | 0 | LAY3_EN<br>Layer3 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |
| 10    | R/W | 0 | LAY2_EN<br>Layer2 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |
| 9     | R/W | 0 | LAY1_EN<br>Layer1 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |
| 8     | R/W | 0 | LAY0_EN<br>Layer0 Enable/Disable<br>0: Disabled<br>1: Enabled                                                                                                                                  |
| 7:2   | /   | / | /                                                                                                                                                                                              |
| 1     | R/W | 0 | START_CTL<br>Normal output channel Start & Reset control<br>0: reset<br>1: start                                                                                                               |
| 0     | R/W | 0 | DEBE_EN<br>DEBE enable/disable<br>0: disable<br>1: enable                                                                                                                                      |

### 33.4.2. DE-Back Color Control Register

| Offset: 0x804 |             |              | Register Name: DEBE_BACKCOLOR_REG |
|---------------|-------------|--------------|-----------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                       |
| 31:24         | /           | /            | /                                 |

|       |     |     |                                                          |
|-------|-----|-----|----------------------------------------------------------|
| 23:16 | R/W | UDF | BK_RED<br>Red<br>Red screen background color value       |
| 15:8  | R/W | UDF | BK_GREEN<br>Green<br>Green screen background color value |
| 7:0   | R/W | UDF | BK_BLUE<br>Blue<br>Blue screen background color value    |

### 33.4.3. DE-Back Display Size Setting Register

| Offset: 0x808 |             |              | Register Name: DEBE_DISSIZE_REG                                                         |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                             |
| 31:16         | R/W         | UDF          | DIS_HEIGHT<br>Display height<br>The real display height = The value of these bits add 1 |
| 15:0          | R/W         | UDF          | DIS_WIDTH<br>Display width<br>The real display width = The value of these bits add 1    |

### 33.4.4. DE-Layer Size Register

| Offset:<br>Layer 0: 0x810<br>Layer 1: 0x814<br>Layer 2: 0x818<br>Layer 3: 0x81C |             |              | Register Name: DEBE_LAYSIZE_REG                                                |
|---------------------------------------------------------------------------------|-------------|--------------|--------------------------------------------------------------------------------|
| Bit                                                                             | Read/Wr ite | Default/ Hex | Description                                                                    |
| 31:29                                                                           | /           | /            | /                                                                              |
| 28:16                                                                           | R/W         | UDF          | LAY_HEIGHT<br>Layer Height<br>The Layer Height = The value of these bits add 1 |
| 15:13                                                                           | /           | /            | /                                                                              |
| 12:0                                                                            | R/W         | UDF          | LAY_WIDTH<br>Layer Width<br>The Layer Width = The value of these bits add 1    |

### 33.4.5. DE-Layer Coordinate Control Register

| Offset:<br>Layer 0: 0x820<br>Layer 1: 0x824 |  | Register Name: DEBE_LAYCOOR_REG |
|---------------------------------------------|--|---------------------------------|
|                                             |  |                                 |

| Layer 2: 0x828<br>Layer 3: 0x82C |             |              |                                                                                                                                       |
|----------------------------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit                              | Read/Wr ite | Default/ Hex | Description                                                                                                                           |
| 31:16                            | R/W         | UDF          | LAY_YCOOR<br>Y coordinate<br>Y is the left-top y coordinate of layer on screen in pixels<br><br>The Y represents the two's complement |
| 15:0                             | R/W         | UDF          | LAY_XCOOR<br>X coordinate<br>X is left-top x coordinate of the layer on screen in pixels<br><br>The X represents the two's complement |

Setting the layer0-layer3 the coordinate (left-top) on screen control information

### 33.4.6. DE-Layer Frame Buffer Line Width Register

| Offset:<br>Layer 0: 0x840<br>Layer 1: 0x844<br>Layer 2: 0x848<br>Layer 3: 0x84C |             |              | Register Name: DEBE_LAYLINEWIDTH_REG                   |
|---------------------------------------------------------------------------------|-------------|--------------|--------------------------------------------------------|
| Bit                                                                             | Read/Wr ite | Default/ Hex | Description                                            |
| 31:0                                                                            | R/W         | UDF          | LAY_LINEWIDTH<br>Layer frame buffer line width in bits |

Note: If the layer is selected by video channel or YUV channel, the setting of this register will be ignored.

### 33.4.7. DE-Layer Frame Buffer Low 32 Bit Address Register

| Offset:<br>Layer 0: 0x850<br>Layer 1: 0x854<br>Layer 2: 0x858<br>Layer 3: 0x85C |             |              | Register Name: DEBE_LAYFB_L32ADD_REG                                            |
|---------------------------------------------------------------------------------|-------------|--------------|---------------------------------------------------------------------------------|
| Bit                                                                             | Read/Wr ite | Default/ Hex | Description                                                                     |
| 31:0                                                                            | R/W         | UDF          | LAYFB_L32ADD<br>Buffer start Address<br>Layer Frame start Buffer Address in bit |

Note: If the layer is selected by video channel or YUV channel, the setting of this register will be ignored.

### 33.4.8. DE-Layer Frame Buffer High 4 Bit Address Register

| Offset: 0x860 |             |              | Register Name: DEBE_LAYFB_H4ADD_REG                         |
|---------------|-------------|--------------|-------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                 |
| 31:28         | /           | /            | /                                                           |
| 27:24         | R/W         | UDF          | LAY3FB_H4ADD<br>Layer3<br>Layer Frame Buffer Address in bit |
| 23:20         | /           | /            | /                                                           |
| 19:16         | R/W         | UDF          | LAY2FB_H4ADD<br>Layer2<br>Layer Frame Buffer Address in bit |
| 15:12         | /           | /            | /                                                           |
| 11:8          | R/W         | UDF          | LAY1FB_H4ADD<br>Layer1<br>Layer Frame Buffer Address in bit |
| 7:4           | /           | /            | /                                                           |
| 3:0           | R/W         | UDF          | LAY0FB_H4ADD<br>Layer0<br>Layer Frame Buffer Address in bit |

Note: If the layer is selected by video channel or YUV channel, the setting of this register will be ignored.

### 33.4.9. DE-Register Buffer Control Register

| Offset: 0x870 |             |              | Register Name: DEBE_REGBUFFCTL_REG                                                                                                                                                                                                   |
|---------------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                          |
| 31:2          | /           | /            | /                                                                                                                                                                                                                                    |
| 1             | R/W         | 0X00         | REGAUTOLOAD_DIS<br>Module registers loading auto mode disable control<br>0: registers auto loading mode<br>1: disable registers auto loading mode, the registers will be loaded by writing 1 to bit0 of this register                |
| 0             | R/W         | 0X00         | REGLOADCTL<br>Register load control<br>When the Module registers loading auto mode disable control bit is set, the registers will be loaded by writing 1 to the bit, and the bit will be self cleared after the registers is loaded. |

### 33.4.10. DE-Color Key MAX Register

|               |                               |
|---------------|-------------------------------|
| Offset: 0x880 | Register Name: DEBE_CKMAX_REG |
|---------------|-------------------------------|

| Bit   | Read/Wr ite | Default/ Hex | Description                             |
|-------|-------------|--------------|-----------------------------------------|
| 31:24 | /           | /            | /                                       |
| 23:16 | R/W         | UDF          | CKMAX_R<br>Red<br>Red color key max     |
| 15:8  | R/W         | UDF          | CKMAX_G<br>Green<br>Green color key max |
| 7:0   | R/W         | UDF          | CKMAX_B<br>Blue<br>Blue color key max   |

### 33.4.11. DE-Color Key MIN Register

| Offset: 0x884 |             |              | Register Name: DEBE_CKMIN_REG           |
|---------------|-------------|--------------|-----------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                             |
| 31:24         | /           | /            | /                                       |
| 23:16         | R/W         | UDF          | CKMIN_R<br>Red<br>Red color key min     |
| 15:8          | R/W         | UDF          | CKMIN_G<br>Green<br>Green color key min |
| 7:0           | R/W         | UDF          | CKMIN_B<br>Blue<br>Blue color key min   |

### 33.4.12. DE-Color Key Configuration Register

| Offset: 0x888 |             |              | Register Name: DEBE_CKCFG_REG                                                                                                                                          |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                                                                                                            |
| 31:06         | /           | /            | /                                                                                                                                                                      |
| 5:4           | R/W         | UDF          | CKR_MATCH<br>Red Match Rule<br>00: always match<br>01: always match<br>10: match if (Color Min=<Color<=Color Max)<br>11: match if (Color>Color Max or Color<Color Min) |
| 3:2           | R/W         | UDF          | CKG_MATCH<br>Green Match Rule<br>00: always match                                                                                                                      |

|     |     |     |                                                                                                                                                                         |
|-----|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | 01: always match<br>10: match if (Color Min=<Color<=Color Max)<br>11: match if (Color>Color Max or Color<Color Min)                                                     |
| 1:0 | R/W | UDF | CKB_MATCH<br>Blue Match Rule<br>00: always match<br>01: always match<br>10: match if (Color Min=<Color<=Color Max)<br>11: match if (Color>Color Max or Color<Color Min) |

### 33.4.13. DE-Layer Attribute Control Register0

| Offset:<br>Layer0: 0x890<br>Layer1: 0x894<br>Layer2: 0x898<br>Layer3: 0x89C |             |              | Register Name: DEBE_ATTCTL_REG0                                                                                                                                                                                                                                                    |
|-----------------------------------------------------------------------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                                         | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                                                                        |
| 31:24                                                                       | R/W         | UDF          | LAY_GLBALPHA<br>Alpha value<br>Alpha value is used for this layer                                                                                                                                                                                                                  |
| 23:22                                                                       | R/W         | UDF          | LAY_WORKMOD<br>Layer working mode selection<br>00: normal mode (Non-Index mode)<br>01: palette mode (Index mode)<br>10: internal frame buffer mode<br>11: gamma correction<br><br>Except the normal mode, if the other working mode is selected, the on chip SRAM will be enabled. |
| 21:20                                                                       | R/W         | UDF          | PREMUL<br>0: normal input layer<br>1: pre-multiply input layer<br>Other: reserved                                                                                                                                                                                                  |
| 19:18                                                                       | R/W         | UDF          | CKEN<br>Color key Mode<br>00: disabled color key<br>01: The layer color key matches another channel pixel data in Alpha Blender1.<br>1x: Reserved<br><br>Only 2 channels pixel data can get to Alpha Blender1 at the same screen coordinate.                                       |

|       |     |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15    | R/W | UDF | <p>LAY_PIPESEL</p> <p>Pipe Select</p> <p>0: select Pipe 0</p> <p>1: select Pipe 1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14:12 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11:10 | R/W | UDF | <p>LAY_PRISEL</p> <p>Priority</p> <p>The rule is: 11&gt;10&gt;01&gt;00</p> <p>When more than 2 layers are enabled, the priority value of each layer must be different, so designers must keep the condition.</p> <p>If more than 1 layers select the same pipe, in the overlapping area, only the pixel of highest priority layer can pass the pipe to blender1.</p> <p>If both 2 pipes are selected by layers, in the overlapping area, the alpha value will use the alpha value of higher priority layer in the blender1.</p> |
| 9:3   | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2     | R/W | UDF | <p>LAY_YUVEN</p> <p>YUV channel selection</p> <p>0: disable</p> <p>1: enable</p> <p>Setting 2 or more layers YUV channel mode is illegal, so programmers should confirm it.</p>                                                                                                                                                                                                                                                                                                                                                 |
| 1     | R/W | UDF | <p>LAY_VDOEN</p> <p>Layer video channel selection enable control</p> <p>0: disable</p> <p>1: enable</p> <p>Normally, one layer can not be set both video channel and YUV channel mode. If both 2 mode are set, the layer will work in video channel mode, and YUV channel mode will be ignored, so programmers should confirm it.</p> <p>Setting 2 or more layers video channel mode is illegal, and programmers should confirm it.</p>                                                                                         |
| 0     | R/W | UDF | <p>LAY_GLBALPHAEN</p> <p>Alpha Enable</p> <p>0: Disabled the alpha value of this register</p> <p>1: Enabled the alpha value of this register for the layer</p>                                                                                                                                                                                                                                                                                                                                                                  |

### 33.4.14. DE-Layer Attribute Control Register1

|         |                                 |
|---------|---------------------------------|
| Offset: | Register Name: DEBE_ATTCTL_REG1 |
|---------|---------------------------------|

| Layer0: 0x8A0<br>Layer1: 0x8A4<br>Layer2: 0x8A8<br>Layer3: 0x8AC |             |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------------------------------------------------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                                              | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:16                                                            | /           | /            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:14                                                            | R/W         | UDF          | <p>LAY_HSCAFCT</p> <p>Setting the internal frame buffer scaling factor, only valid in internal frame buffer mode</p> <p>SH</p> <p>Height scale factor</p> <p>00: no scaling</p> <p>01: *2</p> <p>10: *4</p> <p>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:12                                                            | R/W         | UDF          | <p>LAY_WSCAFCT</p> <p>Setting the internal frame buffer scaling factor, only valid in internal frame buffer mode</p> <p>SW</p> <p>Width scale factor</p> <p>00: no scaling</p> <p>01: *2</p> <p>10: *4</p> <p>11: Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11:8                                                             | R/W         | UDF          | <p>LAY_FBFMT</p> <p>Frame buffer format</p> <p>Normal mode data format</p> <p>0000: mono 1-bpp</p> <p>0001: mono 2-bpp</p> <p>0010: mono 4-bpp</p> <p>0011: mono 8-bpp</p> <p>0100: color 16-bpp (R:6/G:5/B:5)</p> <p>0101: color 16-bpp (R:5/G:6/B:5)</p> <p>0110: color 16-bpp (R:5/G:5/B:6)</p> <p>0111: color 16-bpp (Alpha:1/R:5/G:5/B:5)</p> <p>1000: color 16-bpp (R:5/G:5/B:5/Alpha:1)</p> <p>1001: color 24-bpp (Padding:8/R:8/G:8/B:8)</p> <p>1010: color 32-bpp (Alpha:8/R:8/G:8/B:8)</p> <p>1011: color 24-bpp (R:8/G:8/B:8)</p> <p>1100: color 16-bpp (Alpha:4/R:4/G:4/B:4)</p> <p>1101: color 16-bpp (R:4/G:4/B:4/Alpha:4)</p> <p>Other: Reserved</p> |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                       |
|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | <p>Palette Mode data format</p> <p>In palette mode, the data of external frame buffer is regarded as pattern.</p> <p>0000: 1-bpp</p> <p>0001: 2-bpp</p> <p>0010: 4-bpp</p> <p>0011: 8-bpp</p> <p>other: Reserved</p> <p>Internal Frame buffer mode data format</p> <p>0000: 1-bpp</p> <p>0001: 2-bpp</p> <p>0010: 4-bpp</p> <p>0011: 8-bpp</p> <p>Other: Reserved</p> |
| 7:3 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                                     |
| 2   | R/W | UDF | <p>LAY_BRSWAPEN</p> <p>B R channel swap</p> <p>0: RGB. Follow the bit[11:8]---RGB</p> <p>1: BGR. Swap the B R channel in the data format.</p>                                                                                                                                                                                                                         |
| 1:0 | R/W | UDF | <p>LAY_FBPS</p> <p>PS</p> <p>Pixels Sequence</p> <p>See the follow table “Pixels Sequence”</p>                                                                                                                                                                                                                                                                        |

### 33.4.15. Pixels Sequence Table

DE-layer attribute control register1 [11:08] = FBF (frame buffer format)

DE-layer attribute control register1 [01:00] = PS (pixels sequence)

**Mono or Internal Frame Buffer 1-Bpp Or Palette 1-Bpp Mode : FBF = 0000**

PS=00

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P31 | P30 | P29 | P28 | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 |
| P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=01

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P24 | P25 | P26 | P27 | P28 | P29 | P30 | P31 | P16 | P17 | P18 | P19 | P20 | P21 | P22 | P23 |
| P08 | P09 | P10 | P11 | P12 | P13 | P14 | P15 | P00 | P01 | P02 | P03 | P04 | P05 | P06 | P07 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=10

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 | P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 |
| P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 | P31 | P30 | P29 | P28 | P27 | P26 | P25 | P24 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=11

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P00 | P01 | P02 | P03 | P04 | P05 | P06 | P07 | P08 | P09 | P10 | P11 | P12 | P13 | P14 | P15 |
| P16 | P17 | P18 | P19 | P20 | P21 | P22 | P23 | P24 | P25 | P26 | P27 | P28 | P29 | P30 | P31 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

**Mono or Internal Frame Buffer 2-Bpp Or Palette 2-Bpp Mode : FBF = 0001**

PS=00

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 |
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=01

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P12 | P13 | P14 | P15 | P08 | P09 | P10 | P11 |
| P04 | P05 | P06 | P07 | P00 | P01 | P02 | P03 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=10

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P03 | P02 | P01 | P00 | P07 | P06 | P05 | P04 |
| P11 | P10 | P09 | P08 | P15 | P14 | P13 | P12 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=11

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P00 | P01 | P02 | P03 | P04 | P05 | P06 | P07 |
| P08 | P09 | P10 | P11 | P12 | P13 | P14 | P15 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

**Mono 4-bpp or palette 4-bpp mode : FBF = 0010**

PS=00

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |
|-----|-----|-----|-----|
| P07 | P06 | P05 | P04 |
| P03 | P02 | P01 | P00 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=01

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |
|-----|-----|-----|-----|
| P06 | P07 | P04 | P05 |
| P02 | P03 | P00 | P01 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=10

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |
|-----|-----|-----|-----|
| P01 | P00 | P03 | P02 |
| P05 | P04 | P07 | P06 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=11

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|     |     |     |     |
|-----|-----|-----|-----|
| P00 | P01 | P02 | P03 |
| P04 | P05 | P06 | P07 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

**Mono 8-bpp mode or palette 8-bpp mode : FBF = 0011**

PS=00/11

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|    |    |
|----|----|
| P3 | P2 |
| P1 | P0 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=01/10

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|    |    |
|----|----|
| P0 | P1 |
| P2 | P3 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

**Color 16-bpp mode : FBF = 0100 or 0101 or 0110 or 0111 or 1000**

PS=00

Bit

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16

|    |
|----|
| P1 |
| P0 |

15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00

PS=01

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

P0

P1

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

PS=10/11

Invalid

**Color 24-bpp or 32-bpp mode : FBF = 1001 or 1010**

PS=00/01

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

P0

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

The bytes sequence is ARGB

PS=10/11

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

P0

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

The bytes sequence is BGRA

### 33.4.16. DE-HWC Coordinate Control Register

| Offset: 0x8D8 |             |              | Register Name: DEBE_HWCCTL_REG            |
|---------------|-------------|--------------|-------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                               |
| 31:16         | R/W         | UDF          | HWC_YCOOR<br>Hardware cursor Y coordinate |
| 15:0          | R/W         | UDF          | HWC_XCOOR<br>Hardware cursor X coordinate |

### 33.4.17. DE-HWC Frame Buffer Format Register

| Offset: 0x8E0 |             |              | Register Name: DEBE_HWCFBCTL_REG                                                                                                                         |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                                                                                              |
| 31:24         | R/W         | UDF          | HWC_YCOOROFF<br>Y coordinate offset<br>The hardware cursor is 32*32 2-bpp pattern, this value represent the start position of the cursor in Y coordinate |

|       |     |     |                                                                                                                                                          |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23:16 | R/W | UDF | HWC_XCOOROFF<br>X coordinate offset<br>The hardware cursor is 32*32 2-bpp pattern, this value represent the start position of the cursor in X coordinate |
| 15:6  | /   | /   | /                                                                                                                                                        |
| 5:4   | R/W | UDF | HWC_YSIZE<br>Y size control<br>00: 32pixels per line<br>01: 64pixels per line<br>Other: reserved                                                         |
| 3:2   | R/W | UDF | HWC_XSIZE<br>X size control<br>00: 32pixels per row<br>01: 64pixels per row<br>Other: reserved                                                           |
| 1:0   | R/W | UDF | HWC_FBFMT<br>Pixels format control<br>00: 1bpp<br>01: 2bpp<br>10: 4bpp<br>11: 8bpp                                                                       |

### 33.4.18. DEBE Write Back Control Register

| Offset: 0x8F0 |             |              | Register Name: DEBE_WBCTL_REG                                                                                                                                                                                                                             |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                                               |
| 31:13         | /           | /            | /                                                                                                                                                                                                                                                         |
| 12            | R/W         | UDF          | WB_FMT<br>Write back data format setting<br>0:ARGB (little endian system)<br>1:BGRA (little endian system)                                                                                                                                                |
| 11:10         | /           | /            | /                                                                                                                                                                                                                                                         |
| 9             | R/W         | UDF          | WB_EFLAG<br>Error flag<br>0:/<br>1: write back error                                                                                                                                                                                                      |
| 8             | R/W         | UDF          | WB_STATUS<br>Write-back process status<br>0: write-back end or write-back disable<br>1: write-back in process<br>This flag indicates that a full frame has not been written back to memory. The bit will be set when write-back enable bit is set, and be |

|     |     |     |                                                                                                                                                                                                                                                                                                                                                                |
|-----|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |     | cleared when write-back process ends.                                                                                                                                                                                                                                                                                                                          |
| 7:2 | /   | /   | /                                                                                                                                                                                                                                                                                                                                                              |
| 1   | R/W | UDF | <p>WB_WOC<br/>Write back only control<br/>0: disable the write back only control, the normal channel data of back end will transfer to LCD/TV controller too.<br/>1: enable the write back only function, and the all output data will bypass the LCD/TV controller.</p>                                                                                       |
| 0   | R/W | UDF | <p>WB_EN<br/>Write back enable<br/>0: Disable<br/>1: Enable<br/>If normal channel of back-end is selected by LCD/TV controller (write back only function is disabled), the writing back process will start when write back enable bit is set and a new frame processing begins. The bit will be cleared when the new writing-back frame starts to process.</p> |

### 33.4.19. DEBE Write Back Address Register

| Offset: 0x8F4 |             |              | Register Name: DEBE_WBADD_REG                                  |
|---------------|-------------|--------------|----------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                    |
| 31:0          | R/W         | UDF          | <p>WB_ADD<br/>The start address of write back data in WORD</p> |

### 33.4.20. DEBE Write Back Buffer Line Width Register

| Offset: 0x8F8 |             |              | Register Name: DEBE_WBLINWIDTH_REG                                 |
|---------------|-------------|--------------|--------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                        |
| 31:0          | R/W         | UDF          | <p>WB_LINEWIDTH<br/>Write back image buffer line width in bits</p> |

### 33.4.21. DEBE Input YUV Channel Control Register

| Offset: 0x920 |             |              | Register Name: DEBE_IYUVCTL_REG                                                                                 |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Wr ite | Default/ Hex | Description                                                                                                     |
| 31:15         | /           | /            | /                                                                                                               |
| 14:12         | R/W         | UDF          | <p>IYUV_FBFMT<br/>Input data format<br/>000: planar YUV 411<br/>001: planar YUV 422<br/>010: planar YUV 444</p> |

|       |     |     |                                                                                                                                                                                                                                                                                                                                  |
|-------|-----|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |     | 011: interleaved YUV 422<br>100: interleaved YUV 444<br>Other: illegal                                                                                                                                                                                                                                                           |
| 11:10 | /   | /   | /                                                                                                                                                                                                                                                                                                                                |
| 9:8   | R/W | UDF | IYUV_FBPS<br>Pixel sequence<br>In planar data format mode:<br>00: Y3Y2Y1Y0<br>01: Y0Y1Y2Y3 (the other 2 components are same)<br>Other: illegal<br>In interleaved YUV 422 data format mode:<br>00: UYVY<br>01: YUYV<br>10: VYUY<br>11: YVYU<br>In interleaved YUV 444 data format mode:<br>00: AYUV<br>01: VUYA<br>Other: illegal |
| 7:5   | /   | /   | /                                                                                                                                                                                                                                                                                                                                |
| 4     | R/W | UDF | IYUV_LINNEREN<br>0:<br>liner<br>1:                                                                                                                                                                                                                                                                                               |
| 3:1   | /   | /   | /                                                                                                                                                                                                                                                                                                                                |
| 0     | R/W | UDF | IYUV_EN<br>YUV channel enable control<br>0: disable<br>1: enable                                                                                                                                                                                                                                                                 |

#### Source Data Input Data Ports:

| Input buffer channel | Planar YUV | Interleaved YUV |
|----------------------|------------|-----------------|
| Channel0             | Y          | YUV             |
| Channel1             | U          | -               |
| Channel2             | V          | -               |

#### 33.4.22. DEBE YUV Channel Frame Buffer Address Register

|                                                   |                                 |
|---------------------------------------------------|---------------------------------|
| Offset:<br>Channel 0 : 0x930<br>Channel 1 : 0x934 | Register Name: DEBE_IYUVADD_REG |
|---------------------------------------------------|---------------------------------|

| Channel 2 : 0x938 |             |              |                                                            |
|-------------------|-------------|--------------|------------------------------------------------------------|
| Bit               | Read/Wr ite | Default/ Hex | Description                                                |
| 31:0              | R/W         | UDF          | IYUV_ADD<br>Buffer Address<br>Frame buffer address in BYTE |

### 33.4.23. DEBE YUV Channel Buffer Line Width Register

|                                                                            |                                       |
|----------------------------------------------------------------------------|---------------------------------------|
| Offset:<br><br>Channel 0 : 0x940<br>Channel 1 : 0x944<br>Channel 2 : 0x948 | Register Name: DEBE_IYUVLINewidth_REG |
| Bit                                                                        | Read/Wr ite                           |

**YUV to RGB conversion algorithm formula:**

$$\begin{aligned}
 R &= \\
 &(R \text{ Y component coefficient} * Y) + \\
 &(R \text{ U component coefficient} * U) + \\
 &(R \text{ V component coefficient} * V) + \\
 &\quad R \text{ constant} \\
 \\
 G &= \\
 &(G \text{ Y component coefficient} * Y) + \\
 &(G \text{ U component coefficient} * U) + \\
 &(G \text{ V component coefficient} * V) + \\
 &\quad G \text{ constant} \\
 \\
 B &= \\
 &(B \text{ Y component coefficient} * Y) + \\
 &(B \text{ U component coefficient} * U) + \\
 &(B \text{ V component coefficient} * V) + \\
 &\quad B \text{ constant}
 \end{aligned}$$

### 33.4.24. DEBE Y/G Coefficient Register

|                                                             |                                |
|-------------------------------------------------------------|--------------------------------|
| Offset:<br><br>G/Y component: 0x950<br>R/U component: 0x954 | Register Name: DEBE_YGCOEF_REG |
|-------------------------------------------------------------|--------------------------------|

| B/V component: 0x958 |                |                 |                                                                                 |
|----------------------|----------------|-----------------|---------------------------------------------------------------------------------|
| Bit                  | Read/Wr<br>ite | Default/<br>Hex | Description                                                                     |
| 31:13                | /              | /               | /                                                                               |
| 12:0                 | R/W            | UDF             | IYUV_YGCOEF<br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 33.4.25. DEBE Y/G Constant Register

| Offset: 0x95C |                |                 | Register Name: DEBE_YGCONS_REG                                            |
|---------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                               |
| 31:14         | /              | /               | /                                                                         |
| 13:0          | R/W            | UDF             | IYUV_YGCONS<br>the Y/G constant<br>the value equals to coefficient* $2^4$ |

### 33.4.26. DEBE U/R Coefficient Register

|                                                                                 |                                |
|---------------------------------------------------------------------------------|--------------------------------|
| Offset:<br>G/Y component: 0x960<br>R/U component: 0x964<br>B/V component: 0x968 | Register Name: DEBE_URCOEF_REG |
| Bit                                                                             | Read/Wr<br>ite                 |
| 31:13                                                                           | /                              |
| 12:0                                                                            | R/W                            |

IYUV\_URCOEF  
the U/R coefficient  
the value equals to coefficient\* $2^{10}$

### 33.4.27. DEBE U/R Constant Register

| Offset: 0x96C |                |                 | Register Name: DEBE_URCONS_REG                                            |
|---------------|----------------|-----------------|---------------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                               |
| 31:14         | /              | /               | /                                                                         |
| 13:0          | R/W            | UDF             | IYUV_URCONS<br>the U/R constant<br>the value equals to coefficient* $2^4$ |

### 33.4.28. DEBE V/B Coefficient Register

|                                                         |                                |
|---------------------------------------------------------|--------------------------------|
| Offset:<br>G/Y component: 0x970<br>R/U component: 0x974 | Register Name: DEBE_VBCOEF_REG |
|---------------------------------------------------------|--------------------------------|

| B/V component: 0x978 |                |                 |                                                                                       |
|----------------------|----------------|-----------------|---------------------------------------------------------------------------------------|
| Bit                  | Read/Wr<br>ite | Default/<br>Hex | Description                                                                           |
| 31:13                | /              | /               | /                                                                                     |
| 12:0                 | R/W            | UDF             | IYUV_VBCOEF<br>the V/B coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

### 33.4.29. DEBE V/B Constant Register

| Offset: 0x97C |                |                 | Register Name: DEBE_VBCONS_REG                                                    |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                                       |
| 31:14         | /              | /               | /                                                                                 |
| 13:0          | R/W            | UDF             | IYUV_VBCONS<br>the V/B constant<br>the value equals to coefficient*2 <sup>4</sup> |

### 33.4.30. DEBE Output Color Control Register

| Offset: 0x9C0 |                |                 | Register Name: DEBE_OCCTL_REG                                           |
|---------------|----------------|-----------------|-------------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                             |
| 31:1          | /              | /               | /                                                                       |
| 0             | R/W            | UDF             | OC_EN<br>Color control module enable control<br>0: disable<br>1: enable |

**Color correction conversion algorithm formula:**

$$\begin{aligned}
 R = & \\
 & (R \text{ R component coefficient} * R) + \\
 & (R \text{ G component coefficient} * G) + \\
 & (R \text{ B component coefficient} * B) + \\
 & \text{R constant}
 \end{aligned}$$

$$\begin{aligned}
 G = & \\
 & (G \text{ R component coefficient} * R) + \\
 & (G \text{ G component coefficient} * G) + \\
 & (G \text{ B component coefficient} * B) + \\
 & \text{G constant}
 \end{aligned}$$

$$\begin{aligned}
 B = & \\
 & (B \text{ R component coefficient} * R) +
 \end{aligned}$$

|  |                                                                                      |
|--|--------------------------------------------------------------------------------------|
|  | (B G component coefficient * G) +<br>(B B component coefficient * B) +<br>B constant |
|--|--------------------------------------------------------------------------------------|

### 33.4.31. DEBE Output Color R Coefficient Register

| Offset:<br>R component: 0x9D0<br>G component: 0x9D4<br>B component: 0x9D8 |                |                 | Register Name: DEBE_OCRCOEF_REG                                            |
|---------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit                                                                       | Read/Wr<br>ite | Default/<br>Hex | Description                                                                |
| 31:14                                                                     | /              | /               | /                                                                          |
| 13:0                                                                      | R/W            | UDF             | OC_RCOEF<br>the R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 33.4.32. DEBE Output Color R Constant Register

| Offset: 0x9DC |                |                 | Register Name: DEBE_OCRCONS_REG                                      |
|---------------|----------------|-----------------|----------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                          |
| 31:15         | /              | /               | /                                                                    |
| 14:0          | R/W            | UDF             | OC_RCONS<br>the R constant<br>the value equals to coefficient* $2^4$ |

### 33.4.33. DEBE Output Color G Coefficient Register

| Offset:<br>R component: 0x9E0<br>G component: 0x9E4<br>B component: 0x9E8 |                |                 | Register Name: DEBE_OCGCOEF_REG                                            |
|---------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit                                                                       | Read/Wr<br>ite | Default/<br>Hex | Description                                                                |
| 31:14                                                                     | /              | /               | /                                                                          |
| 13:0                                                                      | R/W            | UDF             | OC_GCOEF<br>the G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 33.4.34. DEBE Output Color G Constant Register

| Offset: 0x9EC |                |                 | Register Name: DEBE_OCGCONS_REG |
|---------------|----------------|-----------------|---------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                     |
| 31:15         | /              | /               | /                               |

|      |     |     |                                                                              |
|------|-----|-----|------------------------------------------------------------------------------|
| 14:0 | R/W | UDF | OC_GCONS<br>the G constant<br>the value equals to coefficient*2 <sup>4</sup> |
|------|-----|-----|------------------------------------------------------------------------------|

### 33.4.35. DEBE Output Color B Coefficient Register

| Offset:<br>G/Y component: 0x9F0<br>R/U component: 0x9F4<br>B/V component: 0x9F8 |                |                 | Register Name: DEBE_OCBCOEF_REG                                                  |
|---------------------------------------------------------------------------------|----------------|-----------------|----------------------------------------------------------------------------------|
| Bit                                                                             | Read/Wr<br>ite | Default/<br>Hex | Description                                                                      |
| 31:14                                                                           | /              | /               | /                                                                                |
| 13:0                                                                            | R/W            | UDF             | OC_BCOEF<br>the B coefficient<br>the value equals to coefficient*2 <sup>10</sup> |

### 33.4.36. DEBE Output Color B Constant Register

| Offset: 0x9FC |                |                 | Register Name: DEBE_OCBCONS_REG                                              |
|---------------|----------------|-----------------|------------------------------------------------------------------------------|
| Bit           | Read/Wr<br>ite | Default/<br>Hex | Description                                                                  |
| 31:15         | /              | /               | /                                                                            |
| 14:0          | R/W            | UDF             | OC_BCONS<br>the B constant<br>the value equals to coefficient*2 <sup>4</sup> |

### 33.4.37. DE-HWC Pattern Memory Block

#### Function:

1bpp:

Bit

31    30    29    28    27    26    25    24    23    22    21    20    19    18    17    16

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| P31 | P30 | P29 | P28 | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 |
| P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

2bpp:

Bit

31    30    29    28    27    26    25    24    23    22    21    20    19    18    17    16

|     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|
| P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 |
| P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

4bpp:

Bit

31    30    29    28    27    26    25    24    23    22    21    20    19    18    17    16

|                                                 |     |     |     |
|-------------------------------------------------|-----|-----|-----|
| P07                                             | P06 | P05 | P04 |
| P03                                             | P02 | P01 | P00 |
| 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 |     |     |     |
| 8bpp:                                           |     |     |     |
| Bit                                             |     |     |     |
| 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |     |     |     |
| P3                                              |     | P2  |     |
| P1                                              |     | P0  |     |
| 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 |     |     |     |

|                          |                |                 |                                                                                                      |
|--------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------|
| Offset:<br>0x4800-0x4BFF |                |                 | DE-HW cursor pattern memory block                                                                    |
| Bit                      | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                          |
| 31:00                    | R/W            | UDF             | Hardware cursor pixel pattern<br>Specify the color displayed for each of the hardware cursor pixels. |

### 33.4.38. DE-HWC Palette Table

|                          |                |                 |                     |
|--------------------------|----------------|-----------------|---------------------|
| Offset:<br>0x4C00-0x4FFF |                |                 | DE-HW palette table |
| Bit                      | Read/Wr<br>ite | Default/<br>Hex | Description         |
| 31:24                    | R/W            | UDF             | Alpha value         |
| 23:16                    | R/W            | UDF             | Red value           |
| 15:08                    | R/W            | UDF             | Green value         |
| 07:00                    | R/W            | UDF             | Blue value          |

The following figure (only with 2bpp mode) shows the RAM array used for hardware cursor palette lookup and the corresponding colors output.



### 33.4.39. Palette Mode

| Offset:<br>Pipe0:0x5000-0x53FF<br>Pipe1:0x5400-0x57FF |             |              | Pipe palette color table SRAM block |
|-------------------------------------------------------|-------------|--------------|-------------------------------------|
| Bit                                                   | Read/Wr ite | Default/ Hex | Description                         |
| 31:24                                                 | R/W         | UDF          | Alpha value                         |
| 23:16                                                 | R/W         | UDF          | Red value                           |
| 15:08                                                 | R/W         | UDF          | Green value                         |
| 07:00                                                 | R/W         | UDF          | Blue value                          |

In this mode, RAM array is used for palette lookup table; each pixel in the layer frame buffer is treated as an index into the RAM array to select the actual color.

The following figure shows the RAM array used for palette lookup and the corresponding colors output.



### 33.4.40. Internal Frame Buffer Mode

In internal frame buffer mode, the RAM array is used as an on-chip frame buffer; each pixel in the RAM array is used to select one of the palette 32-bit colors.

1bpp:

Bit

|     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
| P31 | P30 | P29 | P28 | P27 | P26 | P25 | P24 | P23 | P22 | P21 | P20 | P19 | P18 | P17 | P16 |
| P15 | P14 | P13 | P12 | P11 | P10 | P09 | P08 | P07 | P06 | P05 | P04 | P03 | P02 | P01 | P00 |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

2bpp:

Bit

|     |    |     |    |     |    |     |    |     |    |     |    |     |    |     |    |
|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|-----|----|
| 31  | 30 | 29  | 28 | 27  | 26 | 25  | 24 | 23  | 22 | 21  | 20 | 19  | 18 | 17  | 16 |
| P15 |    | P14 |    | P13 |    | P12 |    | P11 |    | P10 |    | P09 |    | P08 |    |
| P07 |    | P06 |    | P05 |    | P04 |    | P03 |    | P02 |    | P01 |    | P00 |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

4bpp:

Bit

|     |    |    |     |    |    |     |    |    |     |    |    |    |    |    |    |
|-----|----|----|-----|----|----|-----|----|----|-----|----|----|----|----|----|----|
| 31  | 30 | 29 | 28  | 27 | 26 | 25  | 24 | 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
| P07 |    |    | P06 |    |    | P05 |    |    | P04 |    |    |    |    |    |    |
| P03 |    |    | P02 |    |    | P01 |    |    | P00 |    |    |    |    |    |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

8bpp:

Bit

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| P3 |    |    |    |    |    |    |    |    | P2 |    |    |    |    |    |    |
| P1 |    |    |    |    |    |    |    |    | P0 |    |    |    |    |    |    |

15    14    13    12    11    10    09    08    07    06    05    04    03    02    01    00

|                          |                |                 |                                                                                                                  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| Offset:<br>0x4000-0x57FF |                |                 | DE-on chip SRAM block                                                                                            |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                      | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                                      |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:00                    | R/W            | UDF             | Internal frame buffer pixel pattern<br>Specify the color displayed for each of the internal frame buffer pixels. |  |  |  |  |  |  |  |  |  |  |  |  |

### 33.4.41. Internal Frame Buffer Mode Palette Table

|                                                        |                |                 |                    |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------|----------------|-----------------|--------------------|--|--|--|--|--|--|--|--|--|--|--|--|
| Address:<br>Pipe0:0x5000-0x53FF<br>Pipe1:0x5400-0x57FF |                |                 | Pipe palette table |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                                                    | Read/Wr<br>ite | Default/<br>Hex | Description        |  |  |  |  |  |  |  |  |  |  |  |  |
| 31:24                                                  | R/W            | UDF             | Alpha value        |  |  |  |  |  |  |  |  |  |  |  |  |

|       |     |     |             |
|-------|-----|-----|-------------|
| 23:16 | R/W | UDF | Red value   |
| 15:08 | R/W | UDF | Green value |
| 07:00 | R/W | UDF | Blue value  |

The following figure shows the RAM array used for internal frame buffer mode and the corresponding colors output.



### 33.4.42. Gamma Correction Mode

| Offset:<br>0x4400-0x47FF |             |                 | DE-on chip SRAM block   |
|--------------------------|-------------|-----------------|-------------------------|
| Bit                      | Read/Wr ite | Default/<br>Hex | Description             |
| 31:24                    | R/W         | UDF             | Alpha channel intensity |
| 23:16                    | R/W         | UDF             | Red channel intensity   |
| 15:08                    | R/W         | UDF             | Green channel intensity |
| 07:00                    | R/W         | UDF             | Blue channel intensity  |

In gamma correction mode, the RAM array is used for gamma correction; each pixel's alpha, red, green, and blue color component is treated as an index into the SRAM array. The corresponding Alpha, red, green, or blue channel intensity value at that index is used in the actual color.

The following figure shows the RAM array used for gamma correction and the corresponding colors output.

**On chip SRAM array**
**Inputting external  
frame buffer data**

|   |    |     |    |
|---|----|-----|----|
| 5 | 38 | 133 | 28 |
| ⋮ | ⋮  | ⋮   | ⋮  |
| 5 | 38 | 133 | 28 |
| ⋮ | ⋮  | ⋮   | ⋮  |
| ⋮ | ⋮  | ⋮   | ⋮  |

|                |      |      |      |
|----------------|------|------|------|
| $\alpha_0$     | R0   | G0   | B0   |
| $\alpha_1$     | R1   | G1   | B1   |
| ⋮              | ⋮    | ⋮    | ⋮    |
| $\alpha_n$     | Rn   | Gn   | Bn   |
| ⋮              | ⋮    | ⋮    | ⋮    |
| $\alpha_{254}$ | R254 | G254 | B254 |
| $\alpha_{255}$ | R255 | G255 | B255 |

**Output color**

|            |     |      |     |
|------------|-----|------|-----|
| ⋮          | ⋮   | ⋮    | ⋮   |
| $\alpha_5$ | R38 | G133 | B28 |
| ⋮          | ⋮   | ⋮    | ⋮   |
| ⋮          | ⋮   | ⋮    | ⋮   |
| ⋮          | ⋮   | ⋮    | ⋮   |

**On chip SRAM for gamma correction**

### 33.5. Display Engine Memory Mapping

Base Address:  
BE0: 0x01e60000

Offset:

|        |                     |
|--------|---------------------|
| 0x0000 | Reserved            |
| 0x07FF | Registers           |
| 0x0800 | Reserved            |
| 0x0DFF | Reserved            |
| 0x0E00 | Reserved            |
| 0x3FFF | Reserved            |
| 0x4000 | Reserved            |
| 0x43FF | Gamma Table         |
| 0x4400 | HWC Memory Block    |
| 0x47FF | HWC Palette Table   |
| 0x4800 | PIPE0 Palette Table |
| 0x4BFF | PIPE1 Palette Table |
| 0x4C00 | Reserved            |
| 0x4FFF | Reserved            |
| 0x5000 | Reserved            |
| 0x53FF | Reserved            |
| 0x5400 | Reserved            |
| 0x57FF | Reserved            |
| 0x5800 | Reserved            |
| 0xFFFF | Reserved            |

## 34. HDMI Controller

### 34.1. Overview

The Basic Video/Audio features

- HDMI V1.3 compliance
- Support up to 165M pixel/second
- Support Max 1080p resolution
- Support 480I/576I/480P/576P/720P/1080I/1080P at 24/25/30/50/59.9Hz
- Support 24/30/36/48-bit RGB data format, with 2X/4X repeater
- Support up to 8 channel , 24bit PCM(IEC60958)
- Support IEC61937 compress audio formats
- Support 1-bit audio
- Support HD audio (DTS-HD and Dolly MAT, IEC61937 format)
- Hardware Receiver active sense and Hot Plug detect
- Interrupts for programmers

The DDC Master features

- DDC Host Mode operation
- 7-bit addressing
- Arbitration lost and ACK error detection
- Support Slave clock extension
- Support Interrupt/DMA and polling transfer mode
- FIFO flow control by SCL holding
- 16-byte FIFO
- Max 1023-byte data transfer
- Implicit and Explicit offset address transfer
- Support E-DCC read

## 34.2. HDMI Block Diagram



Figure 34-1 HDMI Block Diagram

## 34.3. HDMI Control Register List

| Module Name | Base Address |
|-------------|--------------|
| HDMI        | 0x01C16000   |

| Register Name  | Offset | Description                     |
|----------------|--------|---------------------------------|
| Ctrl           | 0x004  | System Control Register         |
| Int_Status     | 0x008  | Interrupt Register              |
| HPD            | 0x00c  | HDMI Hot Plug Detect Register   |
| VID_Ctrl       | 0x010  | Video Control Register          |
| VID_Timing_0   | 0x014  | Video Timing Register 0         |
| VID_Timing_1   | 0x018  | Video Timing Register 1         |
| VID_Timing_2   | 0x01c  | Video Timing Register 2         |
| VID_Timing_3   | 0x020  | Video Timing Register 3         |
| VID_Timing_4   | 0x024  | Video Timing Register 4         |
| Aud_Ctrl       | 0x040  | Audio Control Register          |
| ADMA_Ctrl      | 0x044  | Audio DMA&FIFO Control Register |
| Aud_Fmt        | 0x048  | Audio Format Control Register   |
| Aud_PCM_Ctrl   | 0x04c  | Audio PCM Control Register      |
| Aud_CTS        | 0x050  | Acr Cts                         |
| Aud_N          | 0x054  | Acr N                           |
| Aud_CH_Status0 | 0x058  | Audio Channel Status Register 0 |
| Aud_CH_Status1 | 0x05c  | Audio Channel Status Register 1 |
| AVI_Info_Pkt   | 0x080  | AVI Info Frame                  |

|                 |       |                               |
|-----------------|-------|-------------------------------|
| Aud_info_Pkt    | 0x0a0 | Audio Info Frame              |
| ACP_Pkt         | 0x0c0 | ACP Packet                    |
| GP_Pkt          | 0x0e0 | General Control Packet        |
| Pad Ctrl0       | 0x200 | PLL/Drv Setting 0             |
| Pad Ctrl1       | 0x204 | PLL/Drv Setting 1             |
| PLL_Ctrl        | 0x208 | PLL/Drv Setting 2             |
| /               | 0x20c | /                             |
| /               | 0x210 | /                             |
| HPD_CEC         | 0x214 | PLL/Drv Setting 5             |
| SPD_Pkt         | 0x240 | SPD Packet                    |
| Pkt_Ctrl0       | 0x2f0 | Packet_Control0               |
| Pkt_Ctrl0       | 0x2f4 | Packet_Control1               |
| /               | 0x300 | /                             |
| /               | 0x304 | /                             |
| /               | 0x308 | /                             |
| /               | 0x30c | /                             |
| /               | 0x310 | /                             |
| Aud_TX_FIFO     | 0x400 | Audio Normal DMA Port         |
| DDC_Ctrl        | 0x500 | DDC Control Register          |
| DDC_Slave_Addr  | 0x504 | DDC Slave Address Register    |
| DDC_Int_Mask    | 0x508 | DDC Interrupt Mask Register   |
| DDC_Int_Status  | 0x50C | DDC Interrupt Status Register |
| DDC_FIFO_Ctrl   | 0x510 | DDC FIFO Control Register     |
| DDC_FIFO_Status | 0x514 | DDC FIFO Status Register      |
| DDC_FIFO_Access | 0x518 | DDC FIFO Access Register      |
| DDC_Byt_Counter | 0x51C | DDC Access Data Byte Number   |
| DDC_Command     | 0x520 | DDC Access Command Register   |
| DDC_ExREG       | 0x524 | DDC Extended Register         |
| DDC_Clock       | 0x528 | DDC Clock Register            |

## 34.4. HDMI Control Register Description

### 34.4.1. System Control Register

| Offset: 0x004 |                |                 | Register name: Ctrl                 |
|---------------|----------------|-----------------|-------------------------------------|
| Bit           | Read/W<br>rite | Default/H<br>ex | Description                         |
| 31            | R/W            | 0               | MODULE_EN<br>0:disable<br>1:enable  |
| 30            | R/W            | 0               | HDCP_EN:<br>0:disable<br>1:reserved |

|      |     |   |                                                         |
|------|-----|---|---------------------------------------------------------|
| 29:2 | /   | / | reserved                                                |
| 1    | R/W | 0 | CLR_AVMUTE:<br>General control packet Clear_AVMUTE flag |
| 0    | R/W | 0 | SET_AVMUTE:<br>General control packet Set_AVMUTE flag   |

### 34.4.2. Interrupt Status Register

| Offset: 0x008 |             |              | Register name: Int_Status                                                                                                                |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                              |
| 31:23         | /           | /            | reserved                                                                                                                                 |
| 22            | R/W         | 0            | AUD_FIFO_UNDER_FLOW Mask<br>0: interrupt disable<br>1: interrupt enable                                                                  |
| 21            | R/W         | 0            | AUD_FIFO_OVER_FLOW Mask<br>0: interrupt disable<br>1: interrupt enable                                                                   |
| 20            | R/W         | 0            | AUD_TRANS_BUSY Mask<br>0: interrupt disable<br>1: interrupt enable                                                                       |
| 19:18         | -           | -            | -                                                                                                                                        |
| 17            | R/W         | 0            | VID_FIFO_OVER_FLOW Mask<br>0: interrupt disable<br>1: interrupt enable                                                                   |
| 16            | R/W         | 0            | VID_FIFO_UNDER_FLOW Mask<br>0: interrupt disable<br>1: interrupt enable                                                                  |
| 15:7          | /           | /            | reserved                                                                                                                                 |
| 6             | R/Clear     | 0            | AUD_FIFO_UNDER_FLOW<br>Audio input FIFO under flow flag<br>0: normal<br>1: under flow happen                                             |
| 5             | R/Clear     | 0            | AUD_FIFO_OVER_FLOW<br>Audio input FIFO overflow flag<br>0: normal<br>1: over flow happens                                                |
| 4             | R/Clear     | 0            | AUD_TRANS_BUSY<br>Audio output transmit flag<br>0: audio data are transmitted as request<br>1: audio data are not transmitted as request |
| 3:2           | /           | /            | reserved                                                                                                                                 |
| 1             | R/Clear     | 0            | VID_FIFO_OVER_FLOW<br>Video input fifo over flow flag                                                                                    |

|   |         |   |                                                                                              |
|---|---------|---|----------------------------------------------------------------------------------------------|
|   |         |   | 0: normal<br>1: over flow happen                                                             |
| 0 | R/Clear | 0 | VID_FIFO_UNDER_FLOW<br>Video input fifo under flow flag<br>0: normal<br>1: under flow happen |

#### 34.4.3. HDMI Hot Plug Register

| Offset: 0x00c |             |              | Register name: HPD                                             |
|---------------|-------------|--------------|----------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                    |
| 31:16         | /           | /            | reserved                                                       |
| 15            | R           | /            | RX_ACTIVE_SENSE(PIN TX2+)<br>1: RX pull high<br>0: RX pull low |
| 14            | R           | /            | RX_ACTIVE_SENSE(PIN TX2-)<br>1: RX pull high<br>0: RX pull low |
| 13            | R           | /            | RX_ACTIVE_SENSE(PIN TX1+)<br>1: RX pull high<br>0: RX pull low |
| 12            | R           | /            | RX_ACTIVE_SENSE(PIN TX1-)<br>1: RX pull high<br>0: RX pull low |
| 11            | R           | /            | RX_ACTIVE_SENSE(PIN TX0+)<br>1: RX pull high<br>0: RX pull low |
| 10            | R           | /            | RX_ACTIVE_SENSE(PIN TX0-)<br>1: RX pull high<br>0: RX pull low |
| 9             | R           | /            | RX_ACTIVE_SENSE(PIN TXC+)<br>1: RX pull high<br>0: RX pull low |
| 8             | R           | /            | RX_ACTIVE_SENSE(PIN TXC-)<br>1: RX pull high<br>0: RX pull low |
| 7:1           | /           | /            | reserved                                                       |
| 0             | R           | 0            | HotPlug_DET<br>1: HPD Detect high<br>0: HPD Detect low         |

#### 34.4.4. Video Control Register

|               |                         |
|---------------|-------------------------|
| Offset: 0x010 | Register name: VID_Ctrl |
|---------------|-------------------------|

| Bits | Read /Write | Default /Hex | Description                                                                                                        |
|------|-------------|--------------|--------------------------------------------------------------------------------------------------------------------|
| 31   | R/W         | 0            | VIDEO_EN<br>0:Video module disable<br>1:Video module operating                                                     |
| 30   | R/W         | 0            | HDMI_MODE:<br>0:DVI<br>1:HDMI                                                                                      |
| 29:6 | /           | /            | reserved                                                                                                           |
| 5    | R/W         | 0            | Video Source Selection<br>0: Video data from RGB inputs<br>1: Video data from embedded ColorBar Generator          |
| 4    | R/W         | 0            | VID_OUTPUT_FMT:<br>video output format<br>0: progress<br>1: interlace                                              |
| 3:2  | R/W         | 00           | VID_COLOR_MODE:<br>video output color mode<br>00: 24-bit RGB<br>01: 30-bit RGB<br>10: 36-bit RGB<br>11: 48-bit RGB |
| 1:0  | R/W         | 00           | REPEATER_SEL:<br>pixel repeater selection<br>00: normal<br>01: 2X<br>10: 4X<br>11: reserved                        |

#### 34.4.5. Video Timing Register0

| Offset: 0x014 |             |              | Register name: VID_Timing_0                                                |
|---------------|-------------|--------------|----------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                |
| 31:28         | /           | /            | reserved                                                                   |
| 27:16         | R/W         | 0            | VID_ACT_V:<br>Video active vertical resolution is :<br>VID_ACT_V+1 pixels  |
| 15:12         | /           | /            | reserved                                                                   |
| 11:0          | R/W         | 0            | VID_ACT_H:<br>Video active horizontal resolution is:<br>VID_ACT_H+1 pixels |

#### **34.4.6. Video Timing Register1**

| Offset: 0x018 |             |              | Register name: VID_Timing_1                                   |
|---------------|-------------|--------------|---------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                   |
| 31:28         | /           | /            | reserved                                                      |
| 27:16         | R/W         | 0            | VID_VBP:<br>Vertical back porch is:<br>VID_VBP+1 TMDS clock   |
| 15:12         | /           | /            | reserved                                                      |
| 11:0          | R/W         | 0            | VID_HBP:<br>Horizontal back porch is:<br>VID_HBP+1 TMDS clock |

#### **34.4.7. Video Timing Register2**

| Offset: 0x01c |             |              | Register name: VID_Timing_2                                    |
|---------------|-------------|--------------|----------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                    |
| 31:28         | /           | /            | reserved                                                       |
| 27:16         | R/W         | 0            | VID_VFP:<br>Vertical front porch is:<br>VID_VFP+1 TMDS clock   |
| 15:12         | /           | /            | reserved                                                       |
| 11:0          | R/W         | 0            | VID_HFP:<br>Horizontal front porch is:<br>VID_HFP+1 TMDS clock |

#### **34.4.8. Video Timing Register3**

| Offset: 0x020 |             |              | Register name: VID_Timing_3                                          |
|---------------|-------------|--------------|----------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                          |
| 31:28         | /           | /            | reserved                                                             |
| 27:16         | R/W         | 0            | VID_VSPW:<br>Vertical sync plus width is:<br>VID_VSPW+1 TMDS clock   |
| 15:12         | /           | /            | reserved                                                             |
| 11:0          | R/W         | 0            | VID_HSPW:<br>Horizontal sync plus width is:<br>VID_HSPW+1 TMDS clock |

#### **34.4.9. Video Timing Register4**

| Offset: 0x024 |      |         | Register name: VID_Timing_4 |
|---------------|------|---------|-----------------------------|
| Bits          | Read | Default | Description                 |

|       | /Writ<br>e | /Hex |                                                                                      |
|-------|------------|------|--------------------------------------------------------------------------------------|
| 31:26 | /          | /    | reserved                                                                             |
| 25:16 | R/W        | 0    | TX_CLOCK<br>Note: normal 10'b11_1110_0000                                            |
| 15:2  | /          | /    | reserved                                                                             |
| 1     | R/W        | 0    | VID_VSYNC_ACTIVE_SEL:<br>Vsync priority selection<br>0: active low<br>1: active high |
| 0     | R/W        | 0    | VID_HSYNC_ACTIVE_SEL:<br>Hsync priority selection<br>0: active low<br>1: active high |

#### 34.4.10. Audio Control Register

| Offset: 0x040 |                |                 | Register name: Aud_Ctrl                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|----------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read<br>/Write | Default<br>/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31            | R/W            | 0               | AUD_EN:<br>0:disable<br>1:enable<br>Audio module enable                                                                                                                                                                                                                                                                                                                                                              |
| 30            | R/W            | 0               | AUD_RST:<br>0: normal<br>1: reset<br>Audio module soft reset<br>Write 1 to reset Audio module, and automatically clear to 0 after reset.<br>Write 0 to this bit has no effect.<br>Note: before changing the audio parameters, the AUD_EN should first be disabled, and then write 1 to AUD_RST to reset the audio module, and when this reset bit returns to 0, then configure the parameters and enable the AUD_EN. |
| 29:0          | /              | /               | reserved                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 34.4.11. Audio DMA&FIFO control Register

| Offset: 0x044 |                |                 | Register name: ADMA_Ctrl                                   |
|---------------|----------------|-----------------|------------------------------------------------------------|
| Bits          | Read<br>/Write | Default<br>/Hex | Description                                                |
| 31            | R/W            | 0               | Audio Source DMA Mode<br>0: dedicated DMA<br>1: normal DMA |

|       |     |   |                                                                                                              |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------|
| 30:26 | /   | / | reserved                                                                                                     |
| 25:24 | R/W | 0 | DMA REQ CRTL<br>00: 1/2 FIFO empty<br>01: 1/4 FIFO empty<br>10: 1/8 FIFO empty<br>11: reserved               |
| 23:20 | /   | / | reserved                                                                                                     |
| 19    | R/W | 0 | AUD_SRC_DMA_SAMPLE_RATE:<br>0: 2 sample per transfer(only AUD_SRC_WORD_LEN = 00)<br>1: 1 sample per transfer |
| 18    | R/W | 0 | AUD_SRC SAMPLE_LAYOUT<br>0: LSB Align<br>1: MSB Align                                                        |
| 17:16 | R/W | 0 | AUD_SRC_WORD_LEN:<br>00: 16-bit<br>01: 20-bit<br>10: 24-bit<br>11: reserved                                  |
| 15    | R/W | 0 | AUD_FIFO_CLEAR:<br>Audio FIFO flush enable<br>0: normal<br>1: clear the audio input FIFO                     |
| 14:1  | /   | / | reserved                                                                                                     |
| 0     | R/W | 0 | AUD_DATA_SEL:<br>0: last sample<br>1: all 0's<br>Audio data to send when FIFO is underflow                   |

#### 34.4.12. Audio Format Control Register

| Offset: 0x048 |             |              | Register name: Aud_Fmt                                                                                                                                |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                           |
| 31            | R/W         | 0            | Audio Source Selection<br>0: Audio data from DMA inputs<br>1: Audio data from embedded Audio Signal Generator<br>Note: DMA input should be 32bit wide |
| 30:26         | /           | /            | reserved                                                                                                                                              |
| 26:24         | R/W         | 0            | AUD_FMT_SEL:<br>Audio format selection<br>000: liner PCM<br>001: IEC61937 compress formats<br>010: HBR audio<br>011: one bit audio                    |

|      |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 1xx: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23:5 | /   | / | reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4    | R/W | 0 | DSD_FMT<br>0: LSB first<br>1:MSB first                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3    | R/W | 0 | AUD_LAYOUT:<br>PCM/1-bit Audio layout selection<br>0: layout 0 (2 channels)<br>1: layout 1 (up to 8 channels)                                                                                                                                                                                                                                                                                                                                               |
| 2:0  | R/W |   | PCM_SRC_CH_CFG (LPCM & One Bit Audio)<br>Source pcm/1-bit audio configuration<br>000: 1channel<br>001: 2 channel<br>010: 3 channel<br>011: 4 channel<br>100: 5 channel<br>101: 6 channel<br>110: 7 channel<br>111: 8 channel<br>Note: this only indicates how many channels of input PCM stream, and does not indicate that the sink can accept it. So the source should check the CA field of the audio info-frame to decide which channel will be output. |

#### 34.4.13. Audio PCM Control Register

| Offset: 0x04c |             |              | Register name: Aud_PCM_Ctrl                                                                                                                                          |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                          |
| 31            | /           | /            | /                                                                                                                                                                    |
| 30:28         | R/W         | 7            | PCM_CH7_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |
| 27            | /           | /            | /                                                                                                                                                                    |
| 26:24         | R/W         | 6            | PCM_CH6_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample                                                                                                |

|       |     |   |                                                                                                                                                                      |
|-------|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | 011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample                                                                          |
| 23    | /   | / | reserved                                                                                                                                                             |
| 22:20 | R/W | 5 | PCM_CH5_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |
| 19    | /   | / | reserved                                                                                                                                                             |
| 18:16 | R/W | 4 | PCM_CH4_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |
| 15    | /   | / | reserved                                                                                                                                                             |
| 14:12 | R/W | 3 | PCM_CH3_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |
| 11    | /   | / | reserved                                                                                                                                                             |
| 10:8  | R/W | 2 | PCM_CH2_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample                                       |

|     |     |   |                                                                                                                                                                      |
|-----|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |     |   | 110: 7th sample<br>111: 8th sample                                                                                                                                   |
| 7   | /   | / | reserved                                                                                                                                                             |
| 6:4 | R/W | 1 | PCM_CH1_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |
| 3   | /   | / | reserved                                                                                                                                                             |
| 2:0 | R/W | 0 | PCM_CH0_MAP:<br>000: 1st sample<br>001: 2nd sample<br>010: 3rd sample<br>011: 4th sample<br>100: 5th sample<br>101: 6th sample<br>110: 7th sample<br>111: 8th sample |

#### 34.4.14. Audio CTS register

| Offset: 0x050 |             |              | Register name: Aud_CTS                                   |
|---------------|-------------|--------------|----------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                              |
| 31:20         | /           | /            | reserved                                                 |
| 19:0          | R/W         | 0            | AUDIO_CLK_GEN_CTS<br>Audio clock regeneration factor CTS |

#### 34.4.15. Audio N register

| Offset: 0x054 |             |              | Register name: Aud_N                                 |
|---------------|-------------|--------------|------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                          |
| 31:20         | /           | /            | reserved                                             |
| 19:0          | R/W         | 0            | AUDIO_CLK_GEN_N<br>Audio clock regeneration factor N |

#### 34.4.16. Audio PCM channel Status 0

| Offset: 0x058 |             |              | Register name: Aud_CH_Status0 |
|---------------|-------------|--------------|-------------------------------|
| Bits          | Read /Write | Default /Hex | Description                   |

|       |     |      |                                                                                                                                                                                                                                                                                                                                         |
|-------|-----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30 | R/W | 0x00 | /                                                                                                                                                                                                                                                                                                                                       |
| 29:28 | R/W | 0x00 | CLK_ACCUR:<br>Clock accuracy tolerance                                                                                                                                                                                                                                                                                                  |
| 27:24 | R/W | 0x00 | FS_FREQ:<br>Sampling frequency setting<br>0000 = 44.1 KHz<br>0010 = 48 KHz<br>0011 = 32 KHz<br>1000 = 88.2 KHz<br>1010 = 96 KHz<br>1100 = 176.4 KHz<br>1110 = 192 KHz                                                                                                                                                                   |
| 23:20 | R/W | 0x00 | CH_NUM<br>Channel number                                                                                                                                                                                                                                                                                                                |
| 19:16 | R/W | 0x00 | SOURCE_NUM<br>Source number                                                                                                                                                                                                                                                                                                             |
| 15:8  | R/W | 0x00 | CATEGORY_CODE<br>Category code                                                                                                                                                                                                                                                                                                          |
| 7:6   | R/W | 0x00 | MODE<br>00: Default Mode<br>01~11: /                                                                                                                                                                                                                                                                                                    |
| 5:3   | R/W | 0x00 | 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: /<br>011: /<br>100~111: Reserved<br>For bit 1 = “1”, other than Linear PCM applications:<br>000: Default state<br>001~111: Reserved |
| 2     | R/W | 0x00 | CP<br>Copyright<br>0: copyright is asserted<br>1: no copyright is asserted                                                                                                                                                                                                                                                              |
| 1     | R/W | 0x00 | AUD_DATA_TYPE<br>Audio Data Type<br>0: Linear PCM Samples<br>1: For non-linear PCM audio such as AC3, DTS, MPEG audio                                                                                                                                                                                                                   |
| 0     | R/W | 0x00 | APP_TYPE<br>Application type<br>0: Consumer Application                                                                                                                                                                                                                                                                                 |

|  |  |  |                                                                    |
|--|--|--|--------------------------------------------------------------------|
|  |  |  | 1: Professional Application<br>Note: This bit must be fixed to "0" |
|--|--|--|--------------------------------------------------------------------|

### 34.4.17. Audio PCM channel Status 1

| Offset: 0x05c |             |              | Register name: Aud_CH_Status1                                                                                                                                                                                                                                                                                          |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                                            |
| 31:10         | /           | /            | reserved                                                                                                                                                                                                                                                                                                               |
| 9:8           | R/W         | 0x00         | CGMS-A<br>00: Copying is permitted without restriction<br>01: One generation of copies may be made<br>10: Condition not be used<br>11: No copying is permitted                                                                                                                                                         |
| 7:4           | R/W         | 0x00         | ORIGINAL_FS<br>Original sampling frequency<br>0000: not indicated<br>0001: 192kHz<br>0010: 12kHz<br>0011: 176.4kHz<br>0100: Reserved<br>0101: 96kHz<br>0110: 8kHz<br>0111: 88.2kHz<br>1000: 16kHz<br>1001: 24kHz<br>1010: 11.025kHz<br>1011: 22.05kHz<br>1100: 32kHz<br>1101: 48kHz<br>1110: Reserved<br>1111: 44.1kHz |
| 3:1           | R/W         | 0x00         | WORD_LEN<br>Sample word length<br>For bit 0 = "0":<br>000: not indicated<br>001: 16 bits<br>010: 18 bits<br>100: 19 bits<br>101: 20 bits<br>110: 17 bits<br>111: Reserved<br><br>For bit 0 = "1":                                                                                                                      |

|   |     |      |                                                                                                                                     |
|---|-----|------|-------------------------------------------------------------------------------------------------------------------------------------|
|   |     |      | 000: not indicated<br>001: 20 bits<br>010: 22 bits<br>100: 23 bits<br>101: 24 bits<br>110: 21 bits                                  |
| 0 | R/W | 0x00 | WORD_LEN_MAX<br>Max word length<br>0: Maximum audio sample word length is 20 bits<br>1: Maximum audio sample word length is 24 bits |

Note: channel status is 192-bit, and bits that not listed above should be set to 0

#### 34.4.18. AVI\_INFO\_FRMAE\_PACKET

| Offset: 0x080 |             |              | Register name: AVI_Info_Pkt |
|---------------|-------------|--------------|-----------------------------|
| BYTE          | Read /Write | Default /Hex | Description                 |
| 0x00          | R/W         | 0x00         | AVI_HB0<br>Packet type      |
| 0x01          | R/W         | 0x00         | AVI_HB1<br>Packet version   |
| 0x02          | R/W         | 0x00         | AVI_HB2<br>Packet length    |
| 0x03          | R/W         | 0x00         | AVI_PB0<br>checksum         |
| 0x04          | R/W         | 0x00         | AVI_PB1<br>AVI data byte 1  |
| 0x05          | R/W         | 0x00         | AVI_PB2<br>AVI data byte 2  |
| 0x06          | R/W         | 0x00         | AVI_PB3<br>AVI data byte 3  |
| 0x07          | R/W         | 0x00         | AVI_PB4<br>AVI data byte 4  |
| 0x08          | R/W         | 0x00         | AVI_PB5<br>AVI data byte 5  |
| 0x09          | R/W         | 0x00         | AVI_PB6<br>AVI data byte 6  |
| 0x0a          | R/W         | 0x00         | AVI_PB7<br>AVI data byte 7  |
| 0x0b          | R/W         | 0x00         | AVI_PB8<br>AVI data byte 8  |
| 0x0c          | R/W         | 0x00         | AVI_PB9<br>AVI data byte 9  |
| 0x0d          | R/W         | 0x00         | AVI_PB10                    |

|      |     |      |                              |
|------|-----|------|------------------------------|
|      |     |      | AVI data byte 10             |
| 0x0e | R/W | 0x00 | AVI_PB11<br>AVI data byte 11 |
| 0x0f | R/W | 0x00 | AVI_PB12<br>AVI data byte 12 |
| 0x10 | R/W | 0x00 | AVI_PB13<br>AVI data byte 13 |

#### 34.4.19. AUDIO\_INFO\_FRMAE\_PACKET

| Offset: 0x0a0 |             |              | Register name: Aud_info_Pkt  |
|---------------|-------------|--------------|------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                  |
| 0x00          | R/W         | 0x00         | AUD_HB0<br>Packet type       |
| 0x01          | R/W         | 0x00         | AUD_HB1<br>Packet version    |
| 0x02          | R/W         | 0x00         | AUD_HB2<br>Packet length     |
| 0x03          | R/W         | 0x00         | AUD_PB0<br>checksum          |
| 0x04          | R/W         | 0x00         | AUD_PB1<br>AUD data byte 1   |
| 0x05          | R/W         | 0x00         | AUD_PB2<br>AUD data byte 2   |
| 0x06          | R/W         | 0x00         | AUD_PB3<br>AUD data byte 3   |
| 0x07          | R/W         | 0x00         | AUD_PB4<br>AUD data byte 4   |
| 0x08          | R/W         | 0x00         | AUD_PB5<br>AUD data byte 5   |
| 0x09          | R/W         | 0x00         | AUD_PB6<br>AUD data byte 6   |
| 0x0a          | R/W         | 0x00         | AUD_PB7<br>AUD data byte 7   |
| 0x0b          | R/W         | 0x00         | AUD_PB8<br>AUD data byte 8   |
| 0x0c          | R/W         | 0x00         | AUD_PB9<br>AUD data byte 9   |
| 0x0d          | R/W         | 0x00         | AUD_PB10<br>AUD data byte 10 |

#### **34.4.20. ACP\_PACKET**

| Offset: 0x0c0 |             |              | Register name: ACP_Pkt                                        |
|---------------|-------------|--------------|---------------------------------------------------------------|
| BYTE          | Read /Write | Default /Hex | Description                                                   |
| 0x00          | R/W         | 0x00         | ACP_HB1<br>ACP_Type                                           |
| 0x01          | R/W         | 0x00         | ACP_HB2<br>Reserved                                           |
| 0x02          | R/W         | 0x00         | ACP_PB0                                                       |
| 0x03          | R/W         | 0x00         | ACP_PB1                                                       |
| 0x04          | R/W         | 0x00         | ACP_PB2                                                       |
| 0x05          | R/W         | 0x00         | ACP_PB3                                                       |
| 0x06          | R/W         | 0x00         | ACP_PB4                                                       |
| 0x07          | R/W         | 0x00         | ACP_PB5                                                       |
| 0x08          | R/W         | 0x00         | ACP_PB6                                                       |
| 0x09          | R/W         | 0x00         | ACP_PB7                                                       |
| 0x0a          | R/W         | 0x00         | ACP_PB8                                                       |
| 0x0b          | R/W         | 0x00         | ACP_PB9                                                       |
| 0x0c          | R/W         | 0x00         | ACP_PB10                                                      |
| 0x0d          | R/W         | 0x00         | ACP_PB11                                                      |
| 0x0e          | R/W         | 0x00         | ACP_PB12                                                      |
| 0x0f          | R/W         | 0x00         | ACP_PB13                                                      |
| 0x10          | R/W         | 0x00         | ACP_PB14                                                      |
| 0x11          | R/W         | 0x00         | ACP_PB15                                                      |
| 0x12          | R/W         | 0x00         | ACP_EN<br>0: disable ACP packet TX<br>1: enable ACP packet TX |

#### **34.4.21. General\_Control\_PACKET**

| Offset: 0x0e0-0x0e9 |             |              | Register name: GP_Pkt     |
|---------------------|-------------|--------------|---------------------------|
| BYTE                | Read /Write | Default /Hex | Description               |
| 0x00                | R/W         | 0x00         | GCP_HB0<br>Packet type    |
| 0x01                | R/W         | 0x00         | GCP_HB1<br>Packet version |
| 0x02                | R/W         | 0x00         | GCP_HB2<br>Packet length  |
| 0x03                | R/W         | 0x00         | GCP_PB0                   |
| 0x04                | R/W         | 0x00         | GCP_PB1                   |
| 0x05                | R/W         | 0x00         | GCP_PB2                   |
| 0x06                | R/W         | 0x00         | GCP_PB3                   |

|      |     |      |         |
|------|-----|------|---------|
| 0x07 | R/W | 0x00 | GCP_PB4 |
| 0x08 | R/W | 0x00 | GCP_PB5 |
| 0x09 | R/W | 0x00 | GCP_PB6 |

#### 34.4.22. SPD\_PACKET

| Offset: 0x240 |             | Register name: SPD_Pkt |             |
|---------------|-------------|------------------------|-------------|
| BYTE          | Read /Write | Default /Hex           | Description |
| 0x00          | R/W         | 0x00                   | USER_HB1    |
| 0x01          | R/W         | 0x00                   | USER_HB2    |
| 0x02          | R/W         | 0x00                   | USER_HB3    |
| 0x03          | R/W         | 0x00                   | USER_PB0    |
| 0x04          | R/W         | 0x00                   | USER_PB1    |
| 0x05          | R/W         | 0x00                   | USER_PB2    |
| 0x06          | R/W         | 0x00                   | USER_PB3    |
| 0x07          | R/W         | 0x00                   | USER_PB4    |
| 0x08          | R/W         | 0x00                   | USER_PB5    |
| 0x09          | R/W         | 0x00                   | USER_PB6    |
| 0x0a          | R/W         | 0x00                   | USER_PB7    |
| 0x0b          | R/W         | 0x00                   | USER_PB8    |
| 0x0c          | R/W         | 0x00                   | USER_PB9    |
| 0x0d          | R/W         | 0x00                   | USER_PB10   |
| 0x0e          | R/W         | 0x00                   | USER_PB11   |
| 0x0f          | R/W         | 0x00                   | USER_PB12   |
| 0x10          | R/W         | 0x00                   | USER_PB13   |
| 0x11          | R/W         | 0x00                   | USER_PB14   |
| 0x12          | R/W         | 0x00                   | USER_PB15   |
| 0x13          | R/W         | 0x00                   | USER_PB16   |
| 0x14          | R/W         | 0x00                   | USER_PB17   |
| 0x15          | R/W         | 0x00                   | USER_PB18   |
| 0x16          | R/W         | 0x00                   | USER_PB19   |
| 0x17          | R/W         | 0x00                   | USER_PB20   |
| 0x18          | R/W         | 0x00                   | USER_PB21   |
| 0x19          | R/W         | 0x00                   | USER_PB22   |
| 0x1a          | R/W         | 0x00                   | USER_PB23   |
| 0x1b          | R/W         | 0x00                   | USER_PB24   |
| 0x1c          | R/W         | 0x00                   | USER_PB25   |
| 0x1d          | R/W         | 0x00                   | USER_PB26   |
| 0x1e          | R/W         | 0x00                   | USER_PB27   |

#### 34.4.23. PLL/DRV Setting 0: Pad Ctrl0

| Offset: 0x200 |  | Register name: Pad_Ctrl0 |
|---------------|--|--------------------------|
|---------------|--|--------------------------|

| Bits  | Read /Write | Default /Hex | Description                               |
|-------|-------------|--------------|-------------------------------------------|
| 31    | R/W         | 0            | BIASEN                                    |
| 30    | R/W         | 0            | LDOCEN                                    |
| 29    | R/W         | 0            | LDODEN                                    |
| 28    | R/W         | 0            | PWENC                                     |
| 27    | R/W         | 0            | PWEND                                     |
| 26    | R/W         | 0            | PWENG                                     |
| 25    | R/W         | 0            | CKEN                                      |
| 24    | R/W         | 0            | SEN                                       |
| 23    | R/W         | 0            | TXEN                                      |
| 22    | R/W         | 0            | Autosync_dis<br>0: enable auto sync<br>1: |
| 21    | R/W         | 0            | Lsb_msb                                   |
| 202:0 | /           | /            | reserved                                  |

#### 34.4.24. PLL/DRV Setting 1: Pad Ctrl1

| Offset: 0x204 |             |              | Register name: Pad_Ctrl1 |
|---------------|-------------|--------------|--------------------------|
| Bits          | Read /Write | Default /Hex | Description              |
| 31:24         | /           | /            | reserved                 |
| 23            | R/W         | 0            | AMP_OPT                  |
| 22            | R/W         | 0            | AMPCK_OPT                |
| 21            | R/W         | 0            | DMPOPT                   |
| 20            | R/W         | 0            | EMP_OPT                  |
| 19            | R/W         | 0            | EMPCK_OPT                |
| 18            | R/W         | 0            | PWSCK                    |
| 17            | R/W         | 0            | PWSDT                    |
| 16            | R/W         | 0            | REG_CSMPS                |
| 15            | R/W         | 0            | REG_DEN                  |
| 14            | R/W         | 0            | REG_DENCK                |
| 13            | R/W         | 0            | REG_PLRCK                |
| 12:10         | R/W         | 0            | REG_EMP                  |
| 9:8           | R/W         | 0            | REG_CD                   |
| 7:6           | R/W         | 0            | REG_CKSS                 |
| 5:3           | R/W         | 0            | REG_AMP                  |
| 2:0           | R/W         | 0            | REG_PLR                  |

#### 34.4.25. PLL/DRV Setting 2: PLL Ctrl0

| Offset: 0x208 |      |         | Register name: PLL_Ctrl |
|---------------|------|---------|-------------------------|
| Bits          | Read | Default | Description             |

|       | /Write | /Hex |             |
|-------|--------|------|-------------|
| 31    | R/W    | 0    | PLL_EN      |
| 30    | R/W    | 0    | BWS         |
| 29    | R/W    | 0    | HV_IS_33    |
| 28    | R/W    | 0    | LDO1_EN     |
| 27    | R/W    | 0    | LDO2_EN     |
| 26    | R/W    | 0    | S6P25_7P5   |
| 25    | R/W    | 0    | SDIV2       |
| 24    | R/W    | 0    | SINT_FRAC   |
| 23    | R/W    | 0    | VCO_GAIN_EN |
| 22:20 | R/W    | 0    | VCO_GAIN    |
| 19:17 | R/W    | 0    | S           |
| 16:12 | R/W    | 0    | CP_S        |
| 11:8  | R/W    | 0    | CS          |
| 7:4   | R/W    | 0    | PREDIV      |
| 3:0   | R/W    | 0    | VCO_S       |

#### 34.4.26. PLL/DRV Setting 5: HPD/CEC

| Offset: 0x214 |             |              | Register name: HPD_CEC |
|---------------|-------------|--------------|------------------------|
| Bits          | Read /Write | Default /Hex | Description            |
| 31:12         | /           | /            | reserved               |
| 11            | R/W         | 0            | REG_CEC_EN             |
| 10            | R/W         | 0            | REG_CECPS              |
| 9             | R/W         | 0            | W_CEC                  |
| 8             | R           | /            | R_CEC                  |
| 7:4           | /           | /            | reserved               |
| 3             | R/W         | 0            | REG_HPD_EN             |
| 2             | R/W         | 0            | REG_HPD_PDPD           |
| 1             | R/W         | 0            | W_HPD                  |
| 0             | R           | /            | R_HPD                  |

#### 34.4.27. PACKET\_Control 0

| Offset: 0x2f0 |             |              | Register name: Pkt_Ctrl0                                    |
|---------------|-------------|--------------|-------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                 |
| 31:28         | R/W         | 0            | Pkt_4_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16 |

|       |     |   |                                                                                                                                            |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | 5: 32<br>6: 64<br>7: 128<br>Others: reserved                                                                                               |
| 27:24 | R/W | 0 | Pkt_3_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved                                |
| 23:20 | R/W | 0 | Pkt_2_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved                                |
| 19:16 | R/W | 0 | Pkt_1_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved                                |
| 15:12 | R/W | 0 | Pkt_4:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: / |

|      |     |   |                                                                                                                                                                                                |
|------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 8: /<br>15:arbiter table end<br>Others: reserved                                                                                                                                               |
| 11:8 | R/W | 0 | Pkt_3:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved |
| 7:4  | R/W | 0 | Pkt_2:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved |
| 3:0  | R/W | 0 | Pkt_1:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved |

#### 34.4.28. PACKET Control 1

| Offset address: 0x2f4 |      | Register name: Pkt_Ctrl1 |             |
|-----------------------|------|--------------------------|-------------|
| Bits                  | Read | Default                  | Description |

|       | /Write | /Hex |                                                                                                             |
|-------|--------|------|-------------------------------------------------------------------------------------------------------------|
| 31:28 | R/W    | 0    | Pkt_8_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved |
| 27:24 | R/W    | 0    | Pkt_7_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved |
| 23:20 | R/W    | 0    | Pkt_6_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved |
| 19:16 | R/W    | 0    | Pkt_5_freq(frame):<br>0: 1<br>1: 2<br>2: 4<br>3: 8<br>4: 16<br>5: 32<br>6: 64<br>7: 128<br>Others: reserved |
| 15:12 | R/W    | 0    | Pkt_8:<br>0: NULL packet                                                                                    |

|      |     |   |                                                                                                                                                                                                |
|------|-----|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved                             |
| 11:8 | R/W | 0 | Pkt_7:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved |
| 7:4  | R/W | 0 | Pkt_6:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /<br>8: /<br>15:arbiter table end<br>Others: reserved |
| 3:0  | R/W | 0 | Pkt_5:<br>0: NULL packet<br>1: gc_packet<br>2: avi_infoframe<br>3: audio_infoframe<br>4: audio_related<br>5: spd_infoframe<br>6: /<br>7: /                                                     |

|  |  |  |                                                  |
|--|--|--|--------------------------------------------------|
|  |  |  | 8: /<br>15:arbiter table end<br>Others: reserved |
|--|--|--|--------------------------------------------------|

#### 34.4.29. Audio Normal DMA Port

| Offset: 0x400 |             |              | Register name: Aud_TX_FIFO                      |
|---------------|-------------|--------------|-------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                     |
| 31:0          | W           | /            | TX_FIFO<br>Audio input FIFO port for normal DMA |

Note: DMA assume that all sample data are organized as 32-bit/sub-frame.

#### 34.4.30. DDC Control Register

| Offset: 0x500 |             |              | Register name: DDC_Ctrl                                                                                                                                                 |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                             |
| 31            | R/W         | 0            | DDC_En                                                                                                                                                                  |
| 30            | R/W         | 0            | DDC Access Command Start<br>Write 1 to this bit will start the DDC Access Command, and will auto cleared when the command ends.<br>Write '0' to this bit has no effect. |
| 29:9          | /           | /            | reserved                                                                                                                                                                |
| 8             | R/W         | 0            | DDC_FIFO_Dir<br>0: read (HOST<=FIFO<=DEVICE)<br>1: write (HOST=>FIFO=>DEVICE)<br>Note: This bit must be set before operation FIFO.                                      |
| 7:1           | R           | 0            | Reserved                                                                                                                                                                |
| 0             | R/W         | 0            | DDC_SW_RST<br>Write "1" to this bit will clear the DDC controller, and clear to "0" when complete soft reset operation                                                  |

#### 34.4.31. DDC Slave Address Register

| Offset: 0x504 |             |              | Register name: DDC_Slave_Addr                                             |
|---------------|-------------|--------------|---------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                               |
| 31:24         | R/W         | 0            | Addr0<br>Segment pointer for E-DDC read operation                         |
| 23:16         | R/W         | 0            | Addr1<br>DDC address for E-DDC read operation                             |
| 15:8          | R/W         | 0            | Addr2<br>Offset address to be sent for non-implicit read/write operation. |
| 6:0           | R/W         | 0            | Addr3                                                                     |

|  |  |  |               |
|--|--|--|---------------|
|  |  |  | Slave Address |
|--|--|--|---------------|

#### 34.4.32. DDC Interrupt Mask Register

| Offset: 0x508 |             |              | Register name: DDC_Int_Mask                                                                                                                                                                                                                                                                          |
|---------------|-------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                                                          |
| 31:6          | /           | /            | reserved                                                                                                                                                                                                                                                                                             |
| 7             | R/W         | 0            | <p>Illegal_FIFO_Op_Int_Msk<br/>0: disable<br/>1: enable<br/>Illegal FIFO operation interrupt mask</p>                                                                                                                                                                                                |
| 6             | R/W         | 0            | <p>DDC_FIFO_Underflow_Int_Mask<br/>0: not underflow<br/>1: underflow<br/>DDC FIFO underflow interrupt mask<br/>This bit is set when FIFO underflows in read operation.<br/>Write 1 to this bit will clear it</p>                                                                                     |
| 5             | R/W         | 0            | <p>DDC_FIFO_Overflow_Int_Mask<br/>0: not overflow<br/>1: overflow<br/>This bit is set when FIFO overflows in write operation.<br/>Write 1 to this bit will clear it</p>                                                                                                                              |
| 4             | R           | 0            | <p>DDC_FIFO_Request_Int_En<br/>This bit is set when FIFO level is below the TX trigger thresh in write operation, or when FIFO level is above the RX trigger thresh in read operation. Write 1 to this bit will clear it.<br/>Note: this bit can only be set when correct FIFO direction is set.</p> |
| 3             | R/W         | 0            | <p>DDC_Arbitration_Error_Int_Mask<br/>0: disable<br/>1: enable</p>                                                                                                                                                                                                                                   |
| 2             | R/W         | 0            | <p>DDC_ACK_Error_Int_Mask<br/>0: disable<br/>1: enable</p>                                                                                                                                                                                                                                           |
| 1             | R/W         | 0            | <p>DDC_Bus_Error_Int_Mask<br/>0: disable<br/>1: enable</p>                                                                                                                                                                                                                                           |
| 0             | R/W         | 0            | <p>DDC_Transfer_Complete_Int_Mask<br/>0: disable<br/>1: enable</p>                                                                                                                                                                                                                                   |

#### 34.4.33. DDC Interrupt Status Register

| Offset: 0x50C |      |         | Register name: DDC_Int_Status |
|---------------|------|---------|-------------------------------|
| Bits          | Read | Default | Description                   |

|      | /Write | /Hex |                                                                                                                                                                                                                                                              |
|------|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /      | /    | reserved                                                                                                                                                                                                                                                     |
| 8    | R      | 0    | <p>Interrupt_Clear_Status<br/>           0: Interrupt have been cleared<br/>           1: Interrupt clear is in process<br/>           Note : When clear interrupt, one must check this bit for clear completion</p>                                         |
| 7    | R/W    | 0    | Illegal_FIFO_operation_interrupt_status_bit                                                                                                                                                                                                                  |
| 6    | R/W    | 0    | <p>DDC_RX FIFO_Underflow_Interrupt_Status_Bit<br/>           0: not underflow<br/>           1: underflow<br/>           This bit is set when FIFO underflows<br/>           Write 1 to this bit will clear it</p>                                           |
| 5    | R/W    | 0    | <p>DDC_TX FIFO_Overflow_Interrupt_Status_Bit<br/>           0: not overflow<br/>           1: overflow<br/>           This bit is set when FIFO overflows<br/>           Write 1 to this bit will clear it</p>                                               |
| 4    | R      | 0    | <p>DDC_FIFO_Request_Interrupt_Status_Bit<br/>           This bit is set when TX FIFO level is below the TX trigger thresh in write operation, or when RX FIFO level is above the RX trigger thresh in read operation. Write 1 to this bit will clear it.</p> |
| 3    | R/W    | 0    | DDC_Arbitration_Error_Interrupt_Status_Bit                                                                                                                                                                                                                   |
| 2    | R/W    | 0    | DDC_ACK_Error_Interrupt_Status_Bit                                                                                                                                                                                                                           |
| 1    | R/W    | 0    | DDC_Bus_Error_Interrupt_Status_Bit                                                                                                                                                                                                                           |
| 0    | R/W    | 0    | DDC_Transfer_Complete_Interrupt_Status_Bit                                                                                                                                                                                                                   |

#### 34.4.34. DDC FIFO Control Register

| Offset: 0x510 |                 |      | Register name: DDC_FIFO_Ctrl                                                                                                                                                 |
|---------------|-----------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | /Read<br>/Write | /Hex | Description                                                                                                                                                                  |
| 31            | R/W             | 0    | <p>FIFO_Address_Clear<br/>           Write '1' to this bit will clear FIFO address, and auto cleared to 0 when complete FIFO addresses clear operation.</p>                  |
| 30:9          | /               | /    | Reserved                                                                                                                                                                     |
| 8             | R/W             | 0    | <p>DMA_Request_En<br/>           0: disable<br/>           1: enable<br/>           Note: this bit can only be set when correct FIFO direction is set</p>                    |
| 7:4           | R/W             | 0    | <p>FIFO_RX_TRIGGER_THRESH<br/>           When FIFO level is above this value in read mode, DMA request and FIFO request interrupt are asserted if relative enable is on.</p> |
| 3:0           | R/W             | 0    | FIFO_TX_TRIGGER_THRESH                                                                                                                                                       |

|  |  |  |                                                                                                                                  |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------|
|  |  |  | When FIFO level is below this value in write mode, DMA request and FIFO request interrupt are asserted if relative enable is on. |
|--|--|--|----------------------------------------------------------------------------------------------------------------------------------|

#### 34.4.35. DDC FIFO Status Register

| Offset: 0x514 |             |              | Register name: DDC_FIFO_Status                                                                                                  |
|---------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                     |
| 31:8          | /           | /            | reserved                                                                                                                        |
| 7             | R           | 0            | FIFO_Request_Ready<br>FIFO level is below FIFO_TX_TRIGGER_THRESH in write mode or is above FIFO_RX_TRIGGER_THRESH in read mode, |
| 6             | R           | 0            | FIFO_FULL                                                                                                                       |
| 5             | R           | 1            | FIFO_EMPTY                                                                                                                      |
| 4:0           | R           | 0            | FIFO_LEVEL                                                                                                                      |

#### 34.4.36. DDC FIFO Access Register

| Offset: 0x518 |             |              | Register name: DDC_FIFO_Access                                                                     |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                        |
| 31:0          | R/W         | 0            | DDC_FIFO_Access_Register<br>Write only in DDC write operation, and read only in DDC read operation |

#### 34.4.37. DDC Access Data Byte Number

| Offset: 0x51C |             |              | Register name: DDC[Byte]_Counter |
|---------------|-------------|--------------|----------------------------------|
| Bits          | Read /Write | Default /Hex | Description                      |
| 31:10         | /           | /            | Reserved                         |
| 9:0           | R/W         | 0            | DDC_Access_Data[Byte]_Number     |

#### 34.4.38. DDC Access Command Register

| Offset: 0x520 |             |              | Register name: DDC_Command                                                                                                                                                                                                                         |
|---------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                        |
| 31:3          | /           | /            | Reserved                                                                                                                                                                                                                                           |
| 2:0           | R/W         | 0            | DDC_Access_Command<br>000 = Abort Current Operation<br>001 = Special Offset Address Read<br>010 = Explicit Offset Address Write<br>011 = Implicit Offset Address Write<br>100 = Explicit Offset Address Read<br>101 = Implicit Offset Address Read |

|  |  |  |                                                                                      |
|--|--|--|--------------------------------------------------------------------------------------|
|  |  |  | 110 = Explicit Offset Address E-DDC Read<br>111 = Implicit Offset Address E-DDC Read |
|--|--|--|--------------------------------------------------------------------------------------|

#### 34.4.39. DDC Extended Register

| Offset: 0x524 |             |              | Register name: DDC_ExREG                                                                                                                                                                        |
|---------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                     |
| 31:11         | /           | /            | Reserved                                                                                                                                                                                        |
| 10            | R           | 0            | Bus_Busy                                                                                                                                                                                        |
| 9             | R           | 0            | SDA_status                                                                                                                                                                                      |
| 8             | R           | 0            | SCL_status                                                                                                                                                                                      |
| 7:4           | /           | /            | Reserved                                                                                                                                                                                        |
| 3             | R/W         | 0            | DDC_SCL_LineState_Control_En<br>0: disable<br>1: enable                                                                                                                                         |
| 2             | R/W         | 0            | DDC_SCL_LineState_Control_Bit<br>When DDC_SCL line state control enable is set to '1', the value of this bit decides the output level of DDC_SCL<br>0: output low level<br>1: output high level |
| 1             | R/W         | 0            | DDC_SDA_LineState_Control_Bit<br>0: disable<br>1: enable                                                                                                                                        |
| 0             | R/W         | 0            | DDC_SDA_LineState_Control_Bit<br>When DDC_SDA line state control enable is set to '1', the value of this bit decides the output level of DDC_SDA<br>0: output low level<br>1: output high level |

#### 34.4.40. DDC Clock Register

| Offset: 0x528 |             |              | Register name: DDC_Clock                                                                                                                                                                                                                                        |
|---------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits          | Read /Write | Default /Hex | Description                                                                                                                                                                                                                                                     |
| 31:7          | /           | /            | reserved                                                                                                                                                                                                                                                        |
| 6:3           | R/W         | 0            | M<br>Note: M is recommended to set to a value greater than 0.                                                                                                                                                                                                   |
| 2:0           | R/W         | 0            | N<br>The DDC bus is sampled by the DCC at the frequency defined by F0:<br>$F_s = F_0 = Fin/2^N$<br>The DDC output frequency is $F_1/10/$ :<br>$F_1 = F_0/(M+1)$<br>$F_{oscl} = F_1/10 = Fin/ (2^N * (M+1) * 10)$<br>The source clock frequency is the fTMDS /2. |



## 35. TCON

### 35.1. TCON Block Diagram



Figure 35-1 TCON Block Diagram

### 35.2. TCON Register List

| Module Name | Base Address |
|-------------|--------------|
| TCON        | 0x01C0C000   |

| Register Name       | Offset | Description                     |
|---------------------|--------|---------------------------------|
| TCON_GCTL_REG       | 0x0000 | TCON Global Control Register    |
| TCON_GINT0_REG      | 0x0004 | TCON Global Interrupt Register0 |
| TCON_GINT1_REG      | 0x0008 | TCON Global Interrupt Register1 |
| TCON0_FRM_CTL_REG   | 0x0010 | TCON FRM Control Register       |
| TCON0_FRM_SEED0_REG | 0x0014 | TCON FRM Seed Register0         |
| TCON0_FRM_SEED1_REG | 0x0018 | TCON FRM Seed Register1         |
| TCON0_FRM_SEED2_REG | 0x001C | TCON FRM Seed Register2         |
| TCON0_FRM_SEED3_REG | 0x0020 | TCON FRM Seed Register3         |
| TCON0_FRM_SEED4_REG | 0x0024 | TCON FRM Seed Register4         |
| TCON0_FRM_SEED5_REG | 0x0028 | TCON FRM Seed Register5         |
| TCON0_FRM_TAB0_REG  | 0x002C | TCON FRM Table Register0        |
| TCON0_FRM_TAB1_REG  | 0x0030 | TCON FRM Table Register1        |
| TCON0_FRM_TAB2_REG  | 0x0034 | TCON FRM Table Register2        |
| TCON0_FRM_TAB3_REG  | 0x0038 | TCON FRM Table Register3        |
| TCON0_CTL_REG       | 0x0040 | TCON0 Control Register          |
| TCON0_DCLK_REG      | 0x0044 | TCON0 Data Clock Register       |

|                       |        |                                     |
|-----------------------|--------|-------------------------------------|
| TCON0_BASIC0_REG      | 0x0048 | TCON0 Basic Timing Register0        |
| TCON0_BASIC1_REG      | 0x004C | TCON0 Basic Timing Register1        |
| TCON0_BASIC2_REG      | 0x0050 | TCON0 Basic Timing Register2        |
| TCON0_BASIC3_REG      | 0x0054 | TCON0 Basic Timing Register3        |
| TCON0_HV_IF_REG       | 0x0058 | TCON0 Hv Panel Interface Register   |
| TCON0_CPU_IF_REG      | 0x0060 | TCON0 CPU Panel Interface Register  |
| TCON0_CPU_WR_REG      | 0x0064 | TCON0 CPU Panel Write Data Register |
| TCON0_CPU_RD0_REG     | 0x0068 | TCON0 CPU Panel Read Data Register0 |
| TCON0_CPU_RD1_REG     | 0x006C | TCON0 CPU Panel Read Data Register1 |
| TCON0_IO_POL_REG      | 0x0088 | TCON0 IO Polarity Register          |
| TCON0_IO_TRI_REG      | 0x008C | TCON0 IO Control Register           |
| TCON1_CTL_REG         | 0x0090 | TCON1 Control Register              |
| TCON1_BASIC0_REG      | 0x0094 | TCON1 Basic Timing Register0        |
| TCON1_BASIC1_REG      | 0x0098 | TCON1 Basic Timing Register1        |
| TCON1_BASIC2_REG      | 0x009C | TCON1 Basic Timing Register2        |
| TCON1_BASIC3_REG      | 0x00A0 | TCON1 Basic Timing Register3        |
| TCON1_BASIC4_REG      | 0x00A4 | TCON1 Basic Timing Register4        |
| TCON1_BASIC5_REG      | 0x00A8 | TCON1 Basic Timing Register5        |
| TCON1_IO_POL_REG      | 0x00F0 | TCON1 IO Polarity Register          |
| TCON1_IO_TRI_REG      | 0x00F4 | TCON1 IO Control Register           |
| TCON_CEU_CTL_REG      | 0x0100 | TCON CEU Control Register           |
| TCON_CEU_COEF0_REG    | 0x0110 | TCON CEU Coefficient Register0      |
| TCON_CEU_COEF1_REG    | 0x0114 | TCON CEU Coefficient Register1      |
| TCON_CEU_COEF2_REG    | 0x0118 | TCON CEU Coefficient Register2      |
| TCON_CEU_COEF3_REG    | 0x011C | TCON CEU Coefficient Register3      |
| TCON_CEU_COEF4_REG    | 0x0120 | TCON CEU Coefficient Register4      |
| TCON_CEU_COEF5_REG    | 0x0124 | TCON CEU Coefficient Register5      |
| TCON_CEU_COEF6_REG    | 0x0128 | TCON CEU Coefficient Register6      |
| TCON_CEU_COEF7_REG    | 0x012C | TCON CEU Coefficient Register7      |
| TCON_CEU_COEF8_REG    | 0x0130 | TCON CEU Coefficient Register8      |
| TCON_CEU_COEF9_REG    | 0x0134 | TCON CEU Coefficient Register9      |
| TCON_CEU_COEF10_REG   | 0x0138 | TCON CEU Coefficient Register10     |
| TCON_CEU_COEF11_REG   | 0x013C | TCON CEU Coefficient Register11     |
| TCON_CEU_COEF12_REG   | 0x0140 | TCON CEU Coefficient Register12     |
| TCON_CEU_COEF13_REG   | 0x0144 | TCON CEU Coefficient Register13     |
| TCON_CEU_COEF14_REG   | 0x0148 | TCON CEU Coefficient Register14     |
| TCON1_FILL_CTL_REG    | 0x0300 | TCON1 Fill Data Control Register    |
| TCON1_FILL_BEGIN0_REG | 0x0304 | TCON1 Fill Data Begin Register0     |
| TCON1_FILL_END0_REG   | 0x0308 | TCON1 Fill Data End Register0       |
| TCON1_FILL_DATA0_REG  | 0x030C | TCON1 Fill Data Value Register0     |
| TCON1_FILL_BEGIN1_REG | 0x0310 | TCON1 Fill Data Begin Register1     |
| TCON1_FILL_END1_REG   | 0x0314 | TCON1 Fill Data End Register1       |

|                       |             |                                 |
|-----------------------|-------------|---------------------------------|
| TCON1_FILL_DATA1_REG  | 0x0318      | TCON1 Fill Data Value Register1 |
| TCON1_FILL_BEGIN2_REG | 0x031C      | TCON1 Fill Data Begin Register2 |
| TCON1_FILL_END2_REG   | 0x0320      | TCON1 Fill Data End Register2   |
| TCON1_FILL_DATA2_REG  | 0x0324      | TCON1 Fill Data Value Register2 |
| TCON1_GAMMA_TABLE_REG | 0x400-0x7FF | TCON1 Gama Table Register       |

### 35.3. TCON Register Description

#### 35.3.1. TCON\_GCTL\_REG

| Offset: 0x000 |                |                 | Register Name: TCON global control register                                                       |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                       |
| 31            | R/W            | 0               | TCON_En<br>0: disable<br>1: enable<br>When it's disabled, the module will be reset to idle state. |
| 30            | R/W            | 0               | TCON_Gamma_En<br>0: disable<br>1: enable                                                          |
| 29:1          | /              | /               | /                                                                                                 |
| 0             | R/W            | 0               | IO_Map_Sel<br>0: TCON0<br>1: TCON1<br>Note: This bit determines which IO_INV/IO_TRI is valid      |

#### 35.3.2. TCON\_GINT0\_REG

| Offset: 0x004 |                |                 | Register Name: TCON global interrupt register0 |
|---------------|----------------|-----------------|------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                    |
| 31            | R/W            | 0               | TCON0_Vb_Int_En<br>0: disable<br>1: enable     |
| 30            | R/W            | 0               | TCON1_Vb_Int_En<br>0: disable<br>1: enable     |
| 29            | R/W            | 0               | TCON0_Line_Int_En<br>0: disable<br>1: enable   |
| 28            | R/W            | 0               | TCON1_Line_Int_En<br>0: disable<br>1: enable   |
| 27:16         | /              | /               | /                                              |

|      |     |   |                                                                                                      |
|------|-----|---|------------------------------------------------------------------------------------------------------|
| 15   | R/W | 0 | TCON0_Vb_Int_Flag<br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it. |
| 14   | R/W | 0 | TCON1_Vb_Int_Flag<br>Asserted during vertical no-display period every frame.<br>Write 0 to clear it. |
| 13   | R/W | 0 | TCON0_Line_Int_Flag<br>trigger when SY0 matches the current TCON0 scan line<br>Write 0 to clear it.  |
| 12   | R/W | 0 | TCON1_Line_Int_Flag<br>trigger when SY1 matches the current TCON1 scan line<br>Write 0 to clear it.  |
| 11:0 | /   | / | /                                                                                                    |

### 35.3.3. TCON\_GINT1\_REG

| Offset: 0x008 |                |                 | Register Name: TCON global interrupt register1                                                                                                                                                 |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                    |
| 31:27         | /              | /               | /                                                                                                                                                                                              |
| 26:16         | R/W            | 0               | TCON0_Line_Int_Num<br>scan line for TCON0 line trigger(including inactive lines)<br>Setting it for the specified line for trigger0.<br>Note: SY0 is writable only when LINE_TRG0 is disabled.  |
| 15:11         | /              | /               | /                                                                                                                                                                                              |
| 10:0          | R/W            | 0               | TCON1_Line_Int_Num<br>scan line for TCON1 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. |

### 35.3.4. TCON0\_FRM\_CTL\_REG

| Offset: 0x010 |                |                 | Register Name: TCON FRM control register                     |
|---------------|----------------|-----------------|--------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                  |
| 31            | R/W            | 0               | TCON0_Frm_En<br>0:disable<br>1:enable                        |
| 30:12         | /              | /               | /                                                            |
| 6             | R/W            | 0               | TCON0_Frm_Mode_R<br>0: 6bit frm output<br>1: 5bit frm output |
| 5             | R/W            | 0               | TCON0_Frm_Mode_G<br>0: 6bit frm output<br>1: 5bit frm output |

|     |     |   |                                                                                                                 |
|-----|-----|---|-----------------------------------------------------------------------------------------------------------------|
| 4   | R/W | 0 | TCON0_Frm_Mode_B<br>0: 6bit frm output<br>1: 5bit frm output                                                    |
| 1:0 | R/W | 0 | TCON0_Frm_Test<br>00: FRM<br>01: half 5/6bit, half FRM<br>10: half 8bit, half FRM<br>11: half 8bit, half 5/6bit |

### 35.3.5. TCON0\_FRM\_SEED\_REG

| Offset: 0x014-0x01C |                |                 | Register Name: TCON FRM pixel seed register |
|---------------------|----------------|-----------------|---------------------------------------------|
| Bit                 | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:25               | /              | /               | /                                           |
| 24:0                | R/W            | 0               | Pixel_Seed_Value<br>Note: avoid set it to 0 |

| Offset: 0x020-0x028 |                |                 | Register Name: TCON FRM line seed register |
|---------------------|----------------|-----------------|--------------------------------------------|
| Bit                 | Read/W<br>rite | Default/<br>Hex | Description                                |
| 31:25               | /              | /               | /                                          |
| 12:0                | R/W            | 0               | Line_Seed_Value<br>Note: avoid set it to 0 |

### 35.3.6. TCON0\_FRM\_TAB\_REG

| Offset: 0x02C-0x038 |                |                 | Register Name: TCON FRM table register |
|---------------------|----------------|-----------------|----------------------------------------|
| Bit                 | Read/W<br>rite | Default/<br>Hex | Description                            |
| 127:0               | R/W            | 0               | Frm_Table_Value                        |

### 35.3.7. TCON0\_CTL\_REG

| Offset: 0x040 |                |                 | Register Name: TCON0 control register                                                                              |
|---------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                        |
| 31            | R/W            | 0               | TCON0_En<br>0: disable<br>1: enable<br>Note: It executes at the beginning of the first blank line of TCON0 timing. |
| 30:26         | /              | /               | /                                                                                                                  |
| 25:24         | R/W            | 0               | TCON0_IF<br>00: HV(Sync+DE)                                                                                        |

|      |     |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------|-----|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 01: 8080 I/F<br>10: TTL I/F<br>11: reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23   | R/W | 0 | TCON0_RG_Swap<br>0: default<br>1: swap RED and BLUE data at FIFO1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 22   | R/W | 0 | TCON0_Test_Value<br>0:all 0s<br>1:all 1s                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 21   | R/W | 0 | TCON0_FIFO1_Rst<br>Write 1 and then 0 at this bit will reset FIFO 1<br>Note: 1 holding time must be more than 1 DCLK                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 20   | R/W | 0 | TCON0_Interlace_En<br>0:disable<br>1:enable<br>NOTE: this flag is valid only when TCON0_EN == 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19:9 | /   | / | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8:4  | R/W | 0 | TCON0_State_Delay<br>STA delay<br>NOTE: valid only when TCON0_EN == 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3:2  | /   | / | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1:0  | R/W | 0 | TCON0_SRC_SEL:<br>00: DE CH1(FIFO1 enable)<br>01: DE CH2(FIFO1 enable)<br>10: DMA 565 input(FIFO1 enable)<br>11: Test intput(FIFO1 disable)<br>Note: These bits are sampled only at the beginning of the first blank line of TCON0 timing. Generally, when input source changes, it will change at the beginning of the first blank line of TCON0 timing.<br>When FIFO1 and FIFO2 select the same source and FIFO2 is enabled, it executes at the beginning of the first blank line of TV timing. Also, TCON0 timing generator will reset to the beginning of the first blank line. |

### 35.3.8. TCON0\_DCLK REG

| Offset: 0x044 |                |                 | Register Name: TCON0 data clock register           |
|---------------|----------------|-----------------|----------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                        |
| 31            | R/W            | 0               | TCON0_Dclk_En                                      |
| 30:6          | /              | /               | /                                                  |
| 6:0           | R/W            | 0               | TCON0_Dclk_Div<br>Tdclk = Tsclk * DCLKDIV<br>Note: |

|  |  |  |                                                                   |
|--|--|--|-------------------------------------------------------------------|
|  |  |  | 1.if dclk1&dclk2 used, DCLKDIV >=6<br>2.if dclk only, DCLKDIV >=4 |
|--|--|--|-------------------------------------------------------------------|

### 35.3.9. TCON0\_BASIC0\_REG

| Offset: 0x048 |                |                 | Register Name: TCON0 basic timing register0 |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:27         | /              | /               | /                                           |
| 26:16         | R/W            | 0               | TCON0_X<br>Panel width is X+1               |
| 15:11         | /              | /               | /                                           |
| 10:0          | R/W            | 0               | TCON0_Y<br>Panel height is Y+1              |

### 35.3.10. TCON0\_BASIC1\_REG

| Offset: 0x04C |                |                 | Register Name: TCON0 basic timing register1                                                                                                                             |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                             |
| 31:28         | /              | /               | /                                                                                                                                                                       |
| 27:16         | R/W            | 0               | HT<br>Thcycle = (HT+1) * Tdclk<br>Note: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:10         | /              | /               | /                                                                                                                                                                       |

### 35.3.11. TCON0\_BASIC2\_REG

| Offset: 0x050 |                |                 | Register Name: TCON0 basic timing register2                      |
|---------------|----------------|-----------------|------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                      |
| 31:21         | /              | /               | /                                                                |
| 27:16         | R/W            | 0               | VT<br>TVT = (VT)/2 * Thsync<br>Note: VT/2 >= (VBP+1 ) + (Y+1) +2 |
| 15:10         | /              | /               | /                                                                |
| 9:0           | R/W            | 0               | VBP<br>Tvbp = (VBP +1) * Thsync                                  |

### 35.3.12. TCON0\_BASIC3\_REG

| Offset: 0x054 |                |                 | Register Name: TCON0 basic timing register3 |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                 |

|       |     |   |                                                            |
|-------|-----|---|------------------------------------------------------------|
| 31:22 | /   | / | /                                                          |
| 25:16 | R/W | 0 | HSPW<br>Thspw = (HSPW+1) * Tdclk<br>Note: HT> (HSPW+1)     |
| 15:10 | /   | / | /                                                          |
| 9:0   | R/W | 0 | VSPW<br>Tvspw = (VSPW+1) * Thsync<br>Note: VT/2 > (VSPW+1) |

### 35.3.13. TCON0\_HV\_IF\_REG

| Offset: 0x058 |                |                 | Register Name: TCON0 hv panel interface register                                                                                                     |
|---------------|----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                          |
| 31            | R/W            | 0               | HV_Mode<br>0: 24bit parallel mode<br>1: 8bit serial mode                                                                                             |
| 30            | R/W            | 0               | Serial_Mode<br>0: 8bit/3cycle RGB serial mode(RGB888)<br>1: 8bit/2cycle YUV serial mode(CCIR656)                                                     |
| 29:28         | /              | /               | /                                                                                                                                                    |
| 27:26         | R/W            | 0               | RGB888_SM0<br>Serial RGB888 mode Output sequence at odd lines of the panel (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            | 0               | RGB888_SM1<br>Serial RGB888 mode Output sequence at even lines of the panel (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 |
| 23:22         | R/W            | 0               | YUV_SM<br>serial YUV mode Output sequence 2-pixel-pair of every scan line<br>00: YUYV<br>01: YVYU<br>10: UYVY<br>11: VYUY                            |
| 21:20         | R/W            | 0               | YUV EAV/SAV F line delay<br>0:F toggle right after active video line<br>1:delay 2 line(CCIR NTSC)                                                    |

|       |   |   |                                        |
|-------|---|---|----------------------------------------|
|       |   |   | 2:delay 3 line(CCIR PAL)<br>3:reserved |
| 19: 0 | / | / | /                                      |

### 35.3.14. TCON0\_CPU\_IF\_REG

| Offset: 0x060 |                |                 | Register Name: TCON0 cpu panel interface register                                                                                                                                                     |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                                                                                           |
| 31:29         | R/W            | 0               | CPU_MOD<br>000: 18bit/256K mode<br>001: 16bit mode0<br>010: 16bit mode1<br>011: 16bit mode2<br>100: 16bit mode3<br>101: 9bit mode<br>110: 8bit 256K mode<br>111: 8bit 65K mode                        |
| 28            | R/W            | 0               | AUTO<br>auto Transfer Mode:<br>If it's 1, all valid data during this frame is written to panel.<br>Note: This bit is sampled by Vsync                                                                 |
| 27            | R/W            | 0               | FLUSH<br>direct transfer mode:<br>If it's enabled, FIFO1 is irrelevant to the HV timing, and pixels data keeps being transferred unless the input FIFO is empty.<br>Data output rate control by DCLK. |
| 26            | R/W            | 0               | DA<br>pin A1 value in 8080 mode auto/flash states                                                                                                                                                     |
| 25            | R/W            | 0               | CA<br>pin A1 value in 8080 mode WR/RD execute                                                                                                                                                         |
| 24            | R/W            | 0               | VSYNC_Cs_Sel<br>0:CS<br>1:VSYNC                                                                                                                                                                       |
| 23            | R              | 0               | Wr_Flag<br>0:write operation ends<br>1:write operation is pending                                                                                                                                     |
| 22            | R              | 0               | Rd_Flag<br>0:read operation ends<br>1:read operation is pending                                                                                                                                       |
| 21:0          | /              | /               | /                                                                                                                                                                                                     |

### 35.3.15. TCON0\_CPU\_WR\_REG

|               |                                                    |
|---------------|----------------------------------------------------|
| Offset: 0x064 | Register Name: TCON0 cpu panel write data register |
|---------------|----------------------------------------------------|

| Bit  | Read/W<br>rite | Default/<br>Hex | Description                                                             |
|------|----------------|-----------------|-------------------------------------------------------------------------|
| 31:0 | /              | /               | /                                                                       |
| 23:0 | W              | 0               | Data_Wr<br>data write on 8080 bus, launch a write operation on 8080 bus |

### 35.3.16. TCON0\_CPU\_RD0\_REG

| Offset: 0x068 |                |                 | Register Name: TCON0 cpu panel read data register0                         |
|---------------|----------------|-----------------|----------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                |
| 31:24         | /              | /               | /                                                                          |
| 23:0          | R              | /               | Data_Rd0<br>data read on 8080 bus, launch a new read operation on 8080 bus |

### 35.3.17. TCON0\_CPU\_RD1\_REG

| Offset: 0x06C |                |                 | Register Name: TCON0 cpu panel read data register1                          |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                 |
| 31:24         | /              | /               | /                                                                           |
| 23:0          | R              | /               | Data_Rd1<br>data read on 8080 bus, without a new read operation on 8080 bus |

### 35.3.18. TCON0\_IO\_POL\_REG

| Offset: 0x088 |                |                 | Register Name: TCON0 IO polarity register                                                                                               |
|---------------|----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                                             |
| 31:30         | /              | /               | /                                                                                                                                       |
| 29:28         | R/W            | 0               | DCLK_Sel<br>00: used DCLK0(normal phase offset)<br>01: used DCLK1(1/3 phase offset)<br>10: used DCLK2(2/3 phase offset)<br>11: reserved |
| 27            | R/W            | 0               | IO3_Inv<br>0: not invert<br>1: invert                                                                                                   |
| 26            | R/W            | 0               | IO2_Inv<br>0: not invert<br>1: invert                                                                                                   |
| 25            | R/W            | 0               | IO1_Inv<br>0: not invert<br>1: invert                                                                                                   |
| 24            | R/W            | 0               | IO0_Inv                                                                                                                                 |

|      |     |   |                                                                                                                                               |
|------|-----|---|-----------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 0: not invert<br>1: invert                                                                                                                    |
| 23:0 | R/W | 0 | Data_Inv<br>TCON0 output port D[23:0] polarity control, with independent bit control:<br>0s: normal polarity<br>1s: invert the specify output |

### 35.3.19. TCON0\_IO\_TRI\_REG

| Offset: 0x08C |                |                 | Register Name: TCON0 IO control register                                                                                  |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                               |
| 31:28         | /              | /               | /                                                                                                                         |
| 27            | R/W            | 1               | IO3_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 26            | R/W            | 1               | IO2_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 25            | R/W            | 1               | IO1_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 24            | R/W            | 1               | IO0_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 23:0          | R/W            | 0xFFFF<br>FF    | Data_Output_Tri_En<br>TCON0 output port D[23:0] output enable, with independent bit control:<br>1s: disable<br>0s: enable |

### 35.3.20. TCON1\_CTL\_REG

| Offset: 0x090 |                |                 | Register Name: TCON1 control register |
|---------------|----------------|-----------------|---------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                           |
| 31            | R/W            | 0               | TCON1_En<br>0: disable<br>1: enable   |
| 30:21         | /              | /               | /                                     |
| 20            | R/W            | 0               | Interlace_En<br>0:disable<br>1:enable |
| 19:9          | /              | /               | /                                     |
| 8:4           | R/W            | 0               | Start_Delay                           |

|  |  |  |                         |
|--|--|--|-------------------------|
|  |  |  | This is for DE1 and DE2 |
|--|--|--|-------------------------|

### 35.3.21. TCON1\_BASIC0\_REG

| Offset: 0x094 |                |                 | Register Name: TCON1 basic timing register0 |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:27         | /              | /               | /                                           |
| 27:16         | R/W            | 0               | TCON1_XI<br>source width is X+1             |
| 15:12         | /              | /               | /                                           |
| 11:0          | R/W            | 0               | TCON1_YI<br>source height is Y+1            |

### 35.3.22. TCON1\_BASIC1\_REG

| Offset: 0x098 |                |                 | Register Name: TCON1 basic timing register1                      |
|---------------|----------------|-----------------|------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                      |
| 31:27         | /              | /               | /                                                                |
| 27:16         | R/W            | 0               | LS_XO<br>width is LS_XO+1                                        |
| 15:12         | /              | /               | /                                                                |
| 11:0          | R/W            | 0               | LS_YO<br>width is LS_YO+1<br>Note: this version LS_YO = TCON1_YI |

### 35.3.23. TCON1\_BASIC2\_REG

| Offset: 0x09C |                |                 | Register Name: TCON1 basic timing register2 |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:27         | /              | /               | /                                           |
| 27:16         | R/W            | 0               | TCON1_XO<br>width is TCON1_XO+1             |
| 15:12         | /              | /               | /                                           |
| 11:0          | R/W            | 0               | TCON1_YO<br>height is TCON1_YO+1            |

### 35.3.24. TCON1\_BASIC3\_REG

| Offset: 0x0A0 |                |                 | Register Name: TCON1 basic timing register3 |
|---------------|----------------|-----------------|---------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                 |
| 31:28         | /              | /               | /                                           |
| 28:16         | R/W            | 0               | HT                                          |

|       |     |   |                                                          |
|-------|-----|---|----------------------------------------------------------|
|       |     |   | horizontal total time<br>Thcycle = (HT+1) * Thdclk       |
| 15:12 | /   | / | /                                                        |
| 11:0  | R/W | 0 | HBP<br>horizontal back porch<br>Thbp = (HBP +1) * Thdclk |

### 35.3.25. TCON1\_BASIC4\_REG

| Offset: 0x0A4 |                |                 | Register Name: TCON1 basic timing register4                       |
|---------------|----------------|-----------------|-------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                       |
| 31:28         | /              | /               | /                                                                 |
| 28:16         | R/W            | 0               | VT<br>horizontal total time (in HD line)<br>Tvt = VT/2 * Th       |
| 15:12         | /              | /               | /                                                                 |
| 11:0          | R/W            | 0               | VBP<br>horizontal back porch (in HD line)<br>Tvbp = (VBP +1) * Th |

### 35.3.26. TCON1\_BASIC5\_REG

| Offset: 0x0A8 |                |                 | Register Name: TCON1 basic timing register5                                                     |
|---------------|----------------|-----------------|-------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                     |
| 31:26         | /              | /               | /                                                                                               |
| 25:16         | R/W            | 0               | HSPW<br>horizontal Sync Pulse Width (in dclk)<br>Thspw = (HSPW+1) * Tdclk<br>Note: HT> (HSPW+1) |
| 15:10         | /              | /               | /                                                                                               |
| 9:0           | R/W            | 0               | VSPW<br>vertical Sync Pulse Width (in lines)<br>Tvspw = (VSPW+1) * Th<br>Note: VT/2 > (VSPW+1)  |

### 35.3.27. TCON1\_IO\_POL\_REG

| Offset: 0x0F0 |                |                 | Register Name: TCON1 IO polarity register |
|---------------|----------------|-----------------|-------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                               |
| 31:28         | /              | /               | /                                         |
| 27            | R/W            | 0               | IO3_Inv<br>0: not invert                  |

|      |     |   |                                                                                                                                            |
|------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------|
|      |     |   | 1: invert                                                                                                                                  |
| 26   | R/W | 0 | IO2_Inv<br>0: not invert<br>1: invert                                                                                                      |
| 25   | R/W | 0 | IO1_Inv<br>0: not invert<br>1: invert                                                                                                      |
| 24   | R/W | 0 | IO0_Inv<br>0: not invert<br>1: invert                                                                                                      |
| 23:0 | R/W | 0 | Data_Inv:TCON1 output port D[23:0] polarity control, with independent bit control:<br>0s: normal polarity<br>1s: invert the specify output |

### 35.3.28. TCON1\_IO\_TRI\_REG

| Offset: 0x0F4 |                |                 | Register Name: TCON1 IO control register                                                                                  |
|---------------|----------------|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                                                                                               |
| 31:28         | /              | /               | /                                                                                                                         |
| 27            | R/W            | 1               | IO3_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 26            | R/W            | 1               | IO2_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 25            | R/W            | 1               | IO1_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 24            | R/W            | 1               | IO0_Output_Tri_En<br>1: disable<br>0: enable                                                                              |
| 27:0          | R/W            | 0xFFFF<br>FF    | Data_Output_Tri_En<br>TCON1 output port D[23:0] output enable, with independent bit control:<br>1s: disable<br>0s: enable |

### 35.3.29. TCON\_CEU\_CTL\_REG

| Offset: 0x100 |                |                 | Register Name: TCON CEU control register |
|---------------|----------------|-----------------|------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                              |
| 31            | R/W            | 0               | CEU_en<br>0: bypass                      |

|      |   |   |           |
|------|---|---|-----------|
|      |   |   | 1: enable |
| 30:0 | / | / | /         |

### 35.3.30. TCON\_CEU\_COEF\_REG

| Offset: 0x110-118,<br>0x120-0x128, 0x130-0x138 |                |                 | Register Name: TCON CEU multiplier coefficient register     |
|------------------------------------------------|----------------|-----------------|-------------------------------------------------------------|
| Bit                                            | Read/W<br>rite | Default/<br>Hex | Description                                                 |
| 31:13                                          | /              | /               | /                                                           |
| 12:0                                           | R/W            | 0               | CEU_Coef_Mul_Value<br>signed 13bit value, range of (-16,16) |

| Offset: x11C,0x12C,0x13C |                |                 | Register Name: TCON CEU add coefficient register                   |
|--------------------------|----------------|-----------------|--------------------------------------------------------------------|
| Bit                      | Read/W<br>rite | Default/<br>Hex | Description                                                        |
| 31:19                    | /              | /               | /                                                                  |
| 18:0                     | R/W            | 0               | CEU_Coef_Add_Value<br>signed 19bit value, range of (-16384, 16384) |

| Offset: 0x140,0x144,0x148 |                |                 | Register Name: TCON CEU range coefficient register          |
|---------------------------|----------------|-----------------|-------------------------------------------------------------|
| Bit                       | Read/W<br>rite | Default/<br>Hex | Description                                                 |
| 31:24                     | /              | /               | /                                                           |
| 23:16                     | R/W            | 0               | CEU_Coef_Range_Min<br>unsigned 8bit value, range of [0,255] |
| 15:8                      | /              | /               | /                                                           |
| 7:0                       | R/W            | 0               | CEU_Coef_Range_Max<br>unsigned 8bit value, range of [0,255] |

### 35.3.31. TCON1\_FILL\_CTL\_REG

| Offset: 0x300 |                |                 | Register Name: TCON1 fill data control register |
|---------------|----------------|-----------------|-------------------------------------------------|
| Bit           | Read/W<br>rite | Default/<br>Hex | Description                                     |
| 31            | R/W            | 0               | TCON1_Fill_En:<br>0: bypass<br>1: enable        |
| 30:0          | /              | /               | /                                               |

### 35.3.32. TCON1\_FILL\_BEGIN\_REG

| Offset: 0x304,0x310,0x31C |                |                 | Register Name: TCON1 fill data begin register |
|---------------------------|----------------|-----------------|-----------------------------------------------|
| Bit                       | Read/W<br>rite | Default/<br>Hex | Description                                   |

|       |     |   |            |
|-------|-----|---|------------|
| 31:24 | /   | / | /          |
| 23:0  | R/W | 0 | Fill_Begin |

### 35.3.33. TCON1\_FILL\_END\_REG

| Offset: 0x308,0x314,0x320 |                | Register Name: TCON1 fill data end register |             |
|---------------------------|----------------|---------------------------------------------|-------------|
| Bit                       | Read/W<br>rite | Default/<br>Hex                             | Description |
| 31:24                     | /              | /                                           | /           |
| 23:0                      | R/W            | 0                                           | Fill_End    |

### 35.3.34. TCON1\_FILL\_DATA\_REG

| Offset: 0x30C,0x318,0x324 |                | Register Name: TCON1 fill data value register |             |
|---------------------------|----------------|-----------------------------------------------|-------------|
| Bit                       | Read/W<br>rite | Default/<br>Hex                               | Description |
| 31:24                     | /              | /                                             | /           |
| 23:0                      | R/W            | 0                                             | Fill_Value  |

# 36. Image Enhancement Processor

## 36.1. Overview

The Image Enhancement Processor (IEP) is capable of adjusting the dynamic range of pictures according to statistics.

## 36.2. IEP Register Description

### 36.2.1. General Control Register

| Offset: 0X0000 |             |              | Register Name: IMGEHC_GNCTL_REG                                                                                                                                                         |
|----------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                             |
| 31             | R/W         | 0            | BIST_EN<br>BIST enable<br>0: disable<br>1: enable                                                                                                                                       |
| 30:10          | /           | /            | /                                                                                                                                                                                       |
| 09:08          | R/W         | 0            | MOD<br>Work mode selection. If bit 0 of the register is set ZERO, the following setting will be ignored.<br>00: Output FIFO mode<br>01: De-flicker mode<br>10: DRC mode<br>11: Reserved |
| 07:01          | /           | /            | /                                                                                                                                                                                       |
| 00             | R/W         | 0            | EN<br>0: disabled the module, and the whole module will be bypassed<br>1: enable                                                                                                        |

### 36.2.2. DRC Size Setting Register

| Offset: 0X0004 |             |              | Register Name: IMGEHC_DRCSIZE_REG                                                      |
|----------------|-------------|--------------|----------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                            |
| 31:28          | /           | /            | /                                                                                      |
| 27:16          | R/W         | 0            | DRC_HEIGHT<br>Display height<br>The real display height = The value of these bits + 1. |
| 15:12          | /           | /            | /                                                                                      |
| 11:00          | R/W         | 0            | DRC_WIDTH<br>Display width<br>The real display width = The value of these bits + 1.    |

### 36.2.3. DRC Control Register

| Offset: 0X0010 |             |              | Register Name: IMGEHC_DRCCTL_REG                                                                                                                                                                                                  |
|----------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                       |
| 31:09          | /           | /            | /                                                                                                                                                                                                                                 |
| 08             | R/W         | 0            | DRC_WIN_EN<br>Output window function enable<br>0: disable<br>1: enable                                                                                                                                                            |
| 07:02          | /           | /            | /                                                                                                                                                                                                                                 |
| 01             | R/W         | 0            | DRC_DBRDY_CTL<br>Only valid when DRC_DB_EN bit is set.<br>If the bit is set, when the SYNC signal is coming, the all double buffered DRC registers will be loaded, and the loading is done, the bit will be cleared automatically |
| 00             | R/W         | 0            | DRC_DB_EN<br>DRC double buffer function enable control<br>0: disable<br>1: enable                                                                                                                                                 |

(LGC = Luminance Gain Coefficient)

### 36.2.4. DRC External LGC Start Address Register

| Offset: 0X0014 |             |              | Register Name: IMGEHC_DRCLGC_STAADD_REG |
|----------------|-------------|--------------|-----------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                             |
| 31:00          | R/W         | 0            | DRC_LGC_STAADD<br>Start address in byte |

Double buffered register of DRC, double buffer function is controlled by DRC\_DB\_EN and DRC\_DBRDY\_CTL bits.

### 36.2.5. DRC Setting Register

| Offset: 0X0018 |             |              | Register Name: IMGEHC_DRC_SET_REG                                                                                                                                                                                                                                                                       |
|----------------|-------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                                                                                                             |
| 31:25          | /           | /            | /                                                                                                                                                                                                                                                                                                       |
| 24             | R/W         | 0            | DRC_GAIN_AUTOLOAD_DIS<br>Only valid when the module is enabled and MOD is DRC mode, or the bit is ignored.<br>If the auto load function is enabled, the DRC luminance gain coefficient will be auto loaded from the external appointed memory address when the SYNC signal (LCD SYNC signal) is coming, |

|       |     |      |                                                                                                                                                                                                                                                |
|-------|-----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |      | otherwise ignore the auto load function.<br>About the calculating way of the external appointed memory address, refer to the DRC external LGC start address register.<br>0: Enable the auto load function<br>1: Disable the auto load function |
| 23:16 | /   | /    | /                                                                                                                                                                                                                                              |
| 15:08 | R/W | 0x80 | DRC_LGC_ABSLUMPERVAL<br>Abs luminance percent value                                                                                                                                                                                            |
| 07:02 | /   | /    | /                                                                                                                                                                                                                                              |
| 01    | R/W | 0x00 | DRC_ADJUST_EN<br>0: disable<br>1: enable                                                                                                                                                                                                       |
| 00    | R/W | 0x00 | DRC_LGC_ABSLUMSHF<br>Abs luminance shift bits<br>0: shift 8bits<br>1: shift 9bits                                                                                                                                                              |

Note: Double buffered register of DRC, double buffer function is controlled by DRC\_DB\_EN and DRC\_DBRDY\_CTL bits.

### 36.2.6. DRC Window Position Register0

| Offset: 0X001C |             |              | Register Name: IMGEHC_DRC_WP_REG0                                                                           |
|----------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                 |
| 31:28          | /           | /            | /                                                                                                           |
| 27:16          | R/W         | 0            | DRC_WIN_TOP<br>Window Top position<br>Top position is the left-top y coordinate of display window in pixels |
| 15:12          | /           | /            | /                                                                                                           |
| 11:00          | R/W         | 0            | DRC_WIN_LEFT<br>Window Left position<br>Left position is left-top x coordinate of display window in pixels  |

### 36.2.7. DRC Window Position Register1

| Offset: 0X0020 |             |              | Register Name: IMGEHC_DRC_WP_REG1                                                                                     |
|----------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                           |
| 31:28          | /           | /            | /                                                                                                                     |
| 27:16          | R/W         | 0            | DRC_WIN_BOT<br>Window Bottom position<br>Bottom position is the right-bottom y coordinate of display window in pixels |
| 15:12          | /           | /            | /                                                                                                                     |

|       |     |   |                                                                                                                       |
|-------|-----|---|-----------------------------------------------------------------------------------------------------------------------|
| 11:00 | R/W | 0 | DRC_WIN_RIGHT<br>Window Right position<br>Right position is the right-bottom x coordinate of display window in pixels |
|-------|-----|---|-----------------------------------------------------------------------------------------------------------------------|

### 36.2.8. DRC Write Back Control Register

| Offset: 0X0024 |             |              | Register Name: IMGEHC_WBCTL_REG0                                                                                                                                                                                |
|----------------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                                                     |
| 31             | R/W         | 0x0          | WB_STATUS<br>Write back process status<br>0: write back end or write back disable<br>1: write back in process                                                                                                   |
| 30:25          | /           | /            | /                                                                                                                                                                                                               |
| 24             | R/W         | 0x0          | WB_FIELD<br>Write back field setting for de-flicker<br>0: top field<br>1: bottom field                                                                                                                          |
| 23:17          | /           | /            | /                                                                                                                                                                                                               |
| 16             | R/W         | 0x0          | WB_FMT<br>Write back data format setting<br>0: ARGB<br>1: BGRA                                                                                                                                                  |
| 15:09          | /           | /            | /                                                                                                                                                                                                               |
| 08             | R/W         | 0x0          | WB_WOC<br>Write back only control<br>0: disable the write back only control, the data will transfer to LCD controller too.<br>1: enable the write back only control, the data won't transfer to LCD controller. |
| 07:02          | /           | /            | /                                                                                                                                                                                                               |
| 00             | R/W         | 0x0          | WB_EN<br>Write back enable<br>0: disable<br>1: enable<br>The bit will be cleared when write back ends.                                                                                                          |

### 36.2.9. DRC Write Back Address Register

| Offset: 0X0028 |             |              | Register Name: IMGEHC_WBADD_REG |
|----------------|-------------|--------------|---------------------------------|
| Bit            | Read/Wr ite | Default/ Hex | Description                     |
| 31:0           | R/W         | 0            | WB_ADD                          |

|  |  |  |                                              |
|--|--|--|----------------------------------------------|
|  |  |  | The start address of write back data in BYTE |
|--|--|--|----------------------------------------------|

### 36.2.10. DRC Write Back Buffer Line Width Register

|                |             |              |                                                            |
|----------------|-------------|--------------|------------------------------------------------------------|
| Offset: 0X002c |             |              | Register Name: IMGEHC_WBLINETH_REG                         |
| Bit            | Read/Wr ite | Default/ Hex | Description                                                |
| 31:0           | R/W         | 0            | WB_LINEWIDTH<br>Write back image buffer line width in BYTE |

### 36.2.11. Luminance Histogram Control Register

|                |             |              |                                                                                                                                                                            |
|----------------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0X0030 |             |              | Register Name: IMGEHC_LHC_REG                                                                                                                                              |
| Bit            | Read/Wr ite | Default/ Hex | Description                                                                                                                                                                |
| 31:2           | /           | /            | /                                                                                                                                                                          |
| 1              | R/W         | 0            | LH_MOD<br>0: Current frame case<br>1: Average case                                                                                                                         |
| 0              | R/W         | 0            | LH_REC_CLR<br>If the bit is set, all of the luminance statistics recording registers will be cleared, and the bit will self-clear when the recording registers is cleared. |

### 36.2.12. Luminance Histogram Threshold Setting Register 0

|                |             |              |                                        |
|----------------|-------------|--------------|----------------------------------------|
| Offset: 0X0034 |             |              | Register Name: IMGEHC_LHT_REG0         |
| Bit            | Read/Wr ite | Default/ Hex | Description                            |
| 31:24          | R/W         | 0x80         | LH_THRES_VAL4<br>Step4 threshold value |
| 23:16          | R/W         | 0x60         | LH_THRES_VAL3<br>Step3 threshold value |
| 15:08          | R/W         | 0x40         | LH_THRES_VAL2<br>Step2 threshold value |
| 07:00          | R/W         | 0x20         | LH_THRES_VAL1<br>Step1 threshold value |

### 36.2.13. Luminance Histogram Threshold Setting Register 1

|                |             |              |                                        |
|----------------|-------------|--------------|----------------------------------------|
| Offset: 0X0038 |             |              | Register Name: IMGEHC_LHT_REG1         |
| Bit            | Read/Wr ite | Default/ Hex | Description                            |
| 31:24          | /           | /            | /                                      |
| 23:16          | R/W         | 0xe0         | LH_THRES_VAL7<br>Step7 threshold value |

|       |     |      |                                        |
|-------|-----|------|----------------------------------------|
| 15:08 | R/W | 0xc0 | LH_THRES_VAL6<br>Step6 threshold value |
| 07:00 | R/W | 0xa0 | LH_THRES_VAL5<br>Step5 threshold value |

When set IMGEHC\_LHT\_REG0 and IMGEHC\_LHT\_REG1, make sure that THRES\_VAL1<THRES\_VAL2<...<THRES\_VAL7.

#### 36.2.14. Luminance Histogram Statistics Lum Recording Register

|                         |             |             |                                          |
|-------------------------|-------------|-------------|------------------------------------------|
| Offset: 0X0040 ~ 0X005C |             |             | Register Name: IMGEHC_LHSLUM_REG         |
| Bit                     | Read/Wr ite | Default/Hex | Description                              |
| 31:00                   | R/W         | 0           | LH_LUM_DATA<br>Luminance statistics data |

#### 36.2.15. Luminance Histogram Statistics Counter Recording Register

|                         |             |             |                                          |
|-------------------------|-------------|-------------|------------------------------------------|
| Offset: 0X0060 ~ 0X007C |             |             | Register Name: IMGEHC_LHSCNT_REG         |
| Bit                     | Read/Wr ite | Default/Hex | Description                              |
| 31:00                   | R/W         | 0           | LH_CNT_DATA<br>Luminance statistics data |

**YUV to RGB conversion algorithm formula:**

$$\begin{aligned}
 R &= \\
 &(R \text{ Y component coefficient} * Y) + \\
 &(R \text{ U component coefficient} * U) + \\
 &(R \text{ V component coefficient} * V) + \\
 &\quad R \text{ constant} \\
 G &= \\
 &(G \text{ Y component coefficient} * Y) + \\
 &(G \text{ U component coefficient} * U) + \\
 &(G \text{ V component coefficient} * V) + \\
 &\quad G \text{ constant} \\
 B &= \\
 &(B \text{ Y component coefficient} * Y) + \\
 &(B \text{ U component coefficient} * U) + \\
 &(B \text{ V component coefficient} * V) + \\
 &\quad B \text{ constant}
 \end{aligned}$$

#### 36.2.16. CSC Y/G Coefficient Register

|                                                           |                                     |
|-----------------------------------------------------------|-------------------------------------|
| Offset:<br>G/Y component: 0X00C0<br>R/U component: 0X00C4 | Register Name: IMGEHC_CSCYGCOFF_REG |
|-----------------------------------------------------------|-------------------------------------|

| B/V component: 0X00C8 |                |                           |                                                                                 |
|-----------------------|----------------|---------------------------|---------------------------------------------------------------------------------|
| Bit                   | Read/Wr<br>ite | Default/<br>Hex           | Description                                                                     |
| 31:13                 | /              | /                         | /                                                                               |
| 12:00                 | R/W            | 0x4a7<br>0x1e6f<br>0x1cbf | CSC_YG_COFF<br>the Y/G coefficient<br>the value equals to coefficient* $2^{10}$ |

### 36.2.17. CSC Y/G Constant Register

| Offset: 0X00CC |                |                 | Register Name: IMGEHC_CSCYGCON_REG                                       |
|----------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit            | Read/Wr<br>ite | Default/<br>Hex | Description                                                              |
| 31:14          | /              | /               | /                                                                        |
| 13:00          | R/W            | 0x877           | CSC_YG_CON<br>the Y/G constant<br>the value equals to coefficient* $2^4$ |

### 36.2.18. CSC U/R Coefficient Register

| Offset:<br>G/Y component: 0X00D0<br>R/U component: 0X00D4<br>B/V component: 0X00D8 | Register Name: IMGEHC_CSCURCOFF_REG |                        |                                                                                 |
|------------------------------------------------------------------------------------|-------------------------------------|------------------------|---------------------------------------------------------------------------------|
| Bit                                                                                | Read/Wr<br>ite                      | Default/<br>Hex        | Description                                                                     |
| 31:13                                                                              | /                                   | /                      | /                                                                               |
| 12:00                                                                              | R/W                                 | 0x4a7<br>0x00<br>0x662 | CSC UR COFF<br>the U/R coefficient<br>the value equals to coefficient* $2^{10}$ |

### 36.2.19. CSC U/R Constant Register

| Offset: 0X00DC |                |                 | Register Name: IMGEHC_CSCURCON_REG                                       |
|----------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit            | Read/Wr<br>ite | Default/<br>Hex | Description                                                              |
| 31:14          | /              | /               | /                                                                        |
| 13:00          | R/W            | 0x3211          | CSC UR CON<br>the U/R constant<br>the value equals to coefficient* $2^4$ |

### 36.2.20. CSC V/B Coefficient Register

|                                                           |                                     |
|-----------------------------------------------------------|-------------------------------------|
| Offset:<br>G/Y component: 0X00E0<br>R/U component: 0X00E4 | Register Name: IMGEHC_CSCVBCOFF_REG |
|-----------------------------------------------------------|-------------------------------------|

| B/V component: 0X00E8 |                |                        |                                                                                 |
|-----------------------|----------------|------------------------|---------------------------------------------------------------------------------|
| Bit                   | Read/Wr<br>ite | Default/<br>Hex        | Description                                                                     |
| 31:13                 | /              | /                      | /                                                                               |
| 12:00                 | R/W            | 0x4a7<br>0x812<br>0x00 | CSC_VB_COFF<br>the V/B coefficient<br>the value equals to coefficient* $2^{10}$ |

### 36.2.21. CSC V/B Constant Register

| Offset: 0X00EC |                |                 | Register Name: IMGEHC_CSCVBCON_REG                                       |
|----------------|----------------|-----------------|--------------------------------------------------------------------------|
| Bit            | Read/Wr<br>ite | Default/<br>Hex | Description                                                              |
| 31:14          | /              | /               | /                                                                        |
| 13:00          | R/W            | 0x2eb1          | CSC_VB_CON<br>the V/B constant<br>the value equals to coefficient* $2^4$ |

### 36.2.22. DRC Spatial Coefficient

| Offset: 0X00F0 ~ 0X00F8 |                |                 | Register Name: IMGEHC_DRCSpacOFF         |
|-------------------------|----------------|-----------------|------------------------------------------|
| Bit                     | Read/Wr<br>ite | Default/<br>Hex | Description                              |
| 31:24                   | /              | /               |                                          |
| 23:16                   | R/W            | 0               | 8 bits unsigned spatial coefficient data |
| 15:08                   | R/W            | 0               | 8 bits unsigned spatial coefficient data |
| 07:00                   | R/W            | 0               | 8 bits unsigned spatial coefficient data |

### 36.2.23. DRC Intensity Coefficient

| Offset: 0X0100 ~ 0X01FC |                |                 | Register Name: IMGEHC_DRCINTCOFF           |
|-------------------------|----------------|-----------------|--------------------------------------------|
| Bit                     | Read/Wr<br>ite | Default/<br>Hex | Description                                |
| 31:24                   | R/W            | 0               | 8 bits unsigned intensity coefficient data |
| 23:16                   | R/W            | 0               | 8 bits unsigned intensity coefficient data |
| 15:08                   | R/W            | 0               | 8 bits unsigned intensity coefficient data |
| 07:00                   | R/W            | 0               | 8 bits unsigned intensity coefficient data |

### 36.2.24. DRC Luminance Gain Coefficient

| Offset: 0X0200 ~ 0X03FC |                |                 | Register Name: IMGEHC_DRCLGCOFF                                                                                                |
|-------------------------|----------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Wr<br>ite | Default/<br>Hex | Description                                                                                                                    |
| 31:16                   | R/W            | 0               | 16bits luminance gain coefficient, unsigned data<br>The high 5 bits is the integer part<br>The low 11 bits is the decimal part |

|       |     |   |                                                                                                                                |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------------------------|
| 15:00 | R/W | 0 | 16bits luminance gain coefficient, unsigned data<br>The high 5 bits is the integer part<br>The low 11 bits is the decimal part |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------------------------|

## 37. Security System (SS)

### 37.1. Overview

The Security System (SS) is one encrypt/ decrypt function accelerator suitable for a variety of applications. It supports both encryption and decryption and several modes. Besides, both CPU mode and DMA method are supported for different applications.

It features:

- Support AES, DES, 3DES, SHA-1, MD5
- Support ECB, CBC modes for AES/DES/3DES
- 128-bits, 192-bits and 256-bits key size for AES
- 160-bits hardware PRNG with 192-bits seed
- Support 32-words RX FIFO and 32-words TX FIFO for high speed application
- Support CPU mode and DMA mode
- Support Interrupt

### 37.2. Security System Block Diagram



Figure37-1 Security System Block Diagram

### 37.3. Security System Register List

| Module Name | Base Address |
|-------------|--------------|
| SS          | 0x01C15000   |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| SS_CTL        | 0x00   | Security Control Register         |
| SS_KEY0       | 0x04   | Security Input Key 0/ PRNG Seed 0 |
| SS_KEY1       | 0x08   | Security Input Key 1/ PRNG Seed 1 |

|           |       |                                             |
|-----------|-------|---------------------------------------------|
| ...       | ...   | ...                                         |
| SS_KEY7   | 0x20  | Security Input Key 7                        |
| SS_IV0    | 0x24  | Security Initialization Vector 0            |
| SS_IV1    | 0x28  | Security Initialization Vector 1            |
| SS_IV2    | 0x2C  | Security Initialization Vector 2            |
| SS_IV3    | 0x30  | Security Initialization Vector 3            |
| SS_CNT0   | 0x34  | Security Preload Counter 0                  |
| SS_CNT1   | 0x38  | Security Preload Counter 1                  |
| SS_CNT2   | 0x3C  | Security Preload Counter 2                  |
| SS_CNT3   | 0x40  | Security Preload Counter 3                  |
| SS_FCSR   | 0x44  | Security FIFO Control/ Status Register      |
| SS_ICSR   | 0x48  | Security Interrupt Control/ Status Register |
| SS_MD0    | 0x4C  | SHA1/MD5 Message Digest 0/PRNG Data0        |
| SS_MD1    | 0x50  | SHA1/MD5 Message Digest 1/PRNG Data1        |
| SS_MD2    | 0x54  | SHA1/MD5 Message Digest 2/PRNG Data2        |
| SS_MD3    | 0x58  | SHA1/MD5 Message Digest 3/PRNG Data3        |
| SS_MD4    | 0x5C  | SHA1/MD5 Message Digest 4/PRNG Data4        |
| SS_RXFIFO | 0x200 | RX FIFO input port                          |
| SS_TXFIFO | 0x204 | TX FIFO output port                         |

## 37.4. Security System Register Description

### 37.4.1. Security System Control Register

|              |            |         |                                                                                                                                                                                                  |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: SS_CTL<br>Default Value: 0x0000_0000                                                                                                                                              |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                      |
| 31:28        | /          | /       | /                                                                                                                                                                                                |
|              |            |         | AES/DES/3DES key select<br>0: Select input SS_KEYx (Normal Mode)<br>1: Select SID_RKEYx from Security ID<br>2: Reserved<br>3-10: Select internal Key n (n from 0 to 7)                           |
| 27:24        | R/W        | 0       | Others: Reserved                                                                                                                                                                                 |
| 18:16        | R          | x       | Reserved                                                                                                                                                                                         |
| 15           | R/W        | 0       | PRNG generator mode<br>0: One-shot mode<br>1: Continue mode                                                                                                                                      |
| 14           | R/W        | 0       | IV Steady of SHA-1/MD5 constants<br>0: Constants<br>1: Arbitrary IV<br>Notes: It is only used for SHA-1/MD5 engine. If the number of IV word is beyond of 4, Counter 0 register is used for IV4. |

|       |     |   |                                                                                                                                                                                                                                                                                                          |
|-------|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |     |   | SS Operation Mode<br>00: Electronic Code Book (ECB) mode<br>01: Cipher Block Chaining (CBC) mode<br>1X: Reserved                                                                                                                                                                                         |
| 13:12 | R/W | 0 | /                                                                                                                                                                                                                                                                                                        |
| 11:10 | /   | / | /                                                                                                                                                                                                                                                                                                        |
|       |     |   | Key Size for AES<br>00: 128-bits<br>01: 192-bits<br>10: 256-bits                                                                                                                                                                                                                                         |
| 9:8   | R/W | 0 | 11: Reserved                                                                                                                                                                                                                                                                                             |
|       |     |   | SS Operation Direction<br>0: Encryption<br>1: Decryption                                                                                                                                                                                                                                                 |
| 7     | R/W | 0 |                                                                                                                                                                                                                                                                                                          |
|       |     |   | SS Method<br>000: AES<br>001: DES<br>010: Triple DES (3DES)<br>011: SHA-1<br>100: MD5<br>101: PRNG                                                                                                                                                                                                       |
| 6:4   | R/W | 0 | Others: Reserved                                                                                                                                                                                                                                                                                         |
| 3     | /   | / | /                                                                                                                                                                                                                                                                                                        |
|       |     |   | SHA-1/MD5 Data End bit<br>Write '1' to tell SHA-1/MD5 engine that the text data ends. If there is some data in FIFO, the engine will fetch these data and process them. After finishing message digest, this bit is cleared to '0' by hardware and message digest can be read out from digest registers. |
| 2     | R/W | 0 | Notes: It is only used for SHA-1/MD5 engine.                                                                                                                                                                                                                                                             |
|       |     |   | PRNG start bit<br>In PRNG one-shot mode, write '1' to start PRNG. After generating one group random data (5 words), this bit is cleared to '0' by hardware.                                                                                                                                              |
| 1     | R/W | 0 |                                                                                                                                                                                                                                                                                                          |
|       |     |   | SS Enable<br>A disable on this bit overrides any other block and flushes all FIFOs.<br>0: Disable<br>1: Enable                                                                                                                                                                                           |
| 0     | R/W | 0 |                                                                                                                                                                                                                                                                                                          |

### 37.4.2. Security System Key [n] Register

|                   |            |                                                        |             |
|-------------------|------------|--------------------------------------------------------|-------------|
| Offset: 0x04 +4*n |            | Register Name: SS_KEY[n]<br>Default Value: 0x0000_0000 |             |
| Bit               | Read/Write | Default                                                | Description |

|      |     |   |                                                    |
|------|-----|---|----------------------------------------------------|
| 31:0 | R/W | 0 | Key[n] Input Value (n= 0~7)/ PRNG Seed[n] (n= 0~5) |
|------|-----|---|----------------------------------------------------|

### 37.4.3. Security System IV[n] Register

|                   |            |         |                                                       |
|-------------------|------------|---------|-------------------------------------------------------|
| Offset: 0x24 +4*n |            |         | Register Name: SS_IV[n]<br>Default Value: 0x0000_0000 |
| Bit               | Read/Write | Default | Description                                           |
| 31:0              | R/W        | 0       | Initialization Vector (IV[n]) Input Value (n= 0~3)    |

### 37.4.4. Security System Counter[n] Register

|                   |            |         |                                                        |
|-------------------|------------|---------|--------------------------------------------------------|
| Offset: 0x34 +4*n |            |         | Register Name: SS_CNT[n]<br>Default Value: 0x0000_0000 |
| Bit               | Read/Write | Default | Description                                            |
| 31:0              | R/W        | 0       | Counter Input Value (n= 0~3)                           |

### 37.4.5. Security System FIFO Control/ Status Register

|              |            |         |                                                                                                                                                                               |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x44 |            |         | Register Name: SS_FCSR<br>Default Value: 0x6000_0F0F                                                                                                                          |
| Bit          | Read/Write | Default | Description                                                                                                                                                                   |
| 31           | /          | /       | /                                                                                                                                                                             |
| 30           | R          | 0x1     | RX FIFO Empty<br>0: No room for new word in RX FIFO<br>1: More than one room for new word in RX FIFO (>= 1 word)                                                              |
| 29:24        | R          | 0x20    | RX FIFO Empty Space Word Counter                                                                                                                                              |
| 23           | /          | /       | /                                                                                                                                                                             |
| 22           | R          | 0       | TX FIFO Data Available Flag<br>0: No available data in TX FIFO<br>1: More than one data in TX FIFO (>= 1 word)                                                                |
| 21:16        | R          | 0       | TX FIFO Available Word Counter                                                                                                                                                |
| 15:13        | /          | /       | /                                                                                                                                                                             |
| 12:8         | R/W        | 0xF     | RX FIFO Empty Trigger Level<br>Interrupt and DMA request trigger level for RXFIFO normal condition<br>Trigger Level = RXTL + 1<br>Notes: RX FIFO is used for input the data.  |
| 7:5          | /          | /       | /                                                                                                                                                                             |
| 4:0          | R/W        | 0xF     | TX FIFO Trigger Level<br>Interrupt and DMA request trigger level for TXFIFO normal condition<br>Trigger Level = TXTL + 1<br>Notes: TX FIFO is used to output the result data. |

### 37.4.6. Security System Interrupt Control/ Status Register

| Offset: 0x48 |            |         | Register Name: SS_ICSR<br>Default Value: 0x0000_0000                                                                                                                                                                                        |
|--------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                 |
| 31:11        | /          | /       | /                                                                                                                                                                                                                                           |
| 10           | R/W        | 0       | RX FIFO Empty Pending bit<br>0: No pending<br>1: RX FIFO Empty pending<br>Notes: Write '1' to clear or automatically clear if interrupt condition fails.                                                                                    |
| 9            | /          | /       | /                                                                                                                                                                                                                                           |
| 8            | R/W        | 0       | TX FIFO Data Available Pending bit<br>0: No TX FIFO pending<br>1: TX FIFO pending<br>Notes: Write '1' to clear or automatically clear if interrupt condition fails.                                                                         |
| 7:5          | /          | /       | /                                                                                                                                                                                                                                           |
| 4            | R/W        | 0       | DRQ Enable<br>0: Disable DRQ (CPU polling mode)<br>1: Enable DRQ (DMA mode)                                                                                                                                                                 |
| 3            | /          | /       | /                                                                                                                                                                                                                                           |
| 2            | R/W        | 0       | RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable<br>Notes: If it is set to '1', when the number of empty room is no smaller than ( $\geq$ ) the preset threshold, the interrupt is triggered and the correspond flag is set.       |
| 1            | /          | /       | /                                                                                                                                                                                                                                           |
| 0            | R/W        | 0       | TX FIFO Data Available Interrupt Enable<br>0: Disable<br>1: Enable<br>Notes: If it is set to '1', when available data number is no smaller than ( $\geq$ ) the preset threshold, the interrupt is triggered and the correspond flag is set. |

### 37.4.7. Security System Message Digest[n] Register

| Offset: 0x4C +4*n |            |         | Register Name: SS_MD[n]<br>Default Value: 0x0000_0000 |
|-------------------|------------|---------|-------------------------------------------------------|
| Bit               | Read/Write | Default | Description                                           |
| 31:0              | R          | 0       | SHA1/ MD5 Message digest MD[n] for SHA1/MD5 (n= 0~4)  |

### 37.4.8. Security System RX FIFO Register

|               |                      |
|---------------|----------------------|
| Offset: 0x200 | Register Name: SS_RX |
|---------------|----------------------|

|      |            |         |                            |
|------|------------|---------|----------------------------|
|      |            |         | Default Value: 0x0000_0000 |
| Bit  | Read/Write | Default | Description                |
| 31:0 | W          | 0       | 32-bits RX FIFO for Input  |

#### 37.4.9. Security System TX FIFO Register

|               |            |         |                            |
|---------------|------------|---------|----------------------------|
|               |            |         | Register Name: SS_TX       |
| Offset: 0x204 |            |         | Default Value: 0x0000_0000 |
| Bit           | Read/Write | Default | Description                |
| 31:0          | R          | 0       | 32-bits TX FIFO for Output |

### 37.5. Security System Clock Requirement

| Clock Name | Description     | Requirement |
|------------|-----------------|-------------|
| ahb_clk    | AHB bus clock   | >=24MHz     |
| ss_clk     | SS serial clock | <= 150MHz   |

### 37.6. Security System Programming Guide

For SHA1,It should be noted the sequence of the message digest.

Let the message,24-bit ASCII string “abc”,the resulting 160-bit message digest for Fips180-2 is :  
a9993e36 4706816a ba3e2571 7850c26c 9cd0d89d

For SHA1 of the Allwinner:

Let the message,24-bit ASCII string “abc”,the read message digest result from SS\_MD[n](n=0~4) register,in Hex:

SS\_MD[0] = a9993e36

SS\_MD[1] = 4706816a

SS\_MD[2] = ba3e2571

SS\_MD[3] = 7850c26c

SS\_MD[4] = 9cd0d89d

It is worth noting that SHA1 is a big-endian algorithm, the most significant bit is stored in the left-most bit position. But the default access mode of ARM is litter-endian ,so every word of SS\_MD[n](n=0~4) register need convert the byte sequence by the software.

## 38. Security ID

### 38.1. Overview

There is one on chip 128-bit EFUSE for security application. It can also be used as root key or for other purposes.

It features:

- 128-bit electrical fuses for root key

### 38.2. Security ID Register List

| Module Name | Base Address |
|-------------|--------------|
| SID         | 0x01c23800   |

| Register Name | Offset | Description      |
|---------------|--------|------------------|
| SID_RKEY0     | 0x00   | Root Key[31:0]   |
| SID_RKEY1     | 0x04   | Root Key[63:32]  |
| SID_RKEY2     | 0x08   | Root Key[95:64]  |
| SID_RKEY3     | 0x0c   | Root Key[127:96] |

### 38.3. Security ID Register Description

#### 38.3.1. SID Root Key 0 Register

|              |            |         |                                                        |
|--------------|------------|---------|--------------------------------------------------------|
| Offset: 0x00 |            |         | Register Name: SID_RKEY0<br>Default Value: 0xXXXX_XXXX |
| Bit          | Read/Write | Default | Description                                            |
| 31:0         | R          | x       | Security root key[31:0]                                |

#### 38.3.2. SID Root Key 1 Register

|              |            |         |                                                        |
|--------------|------------|---------|--------------------------------------------------------|
| Offset: 0x04 |            |         | Register Name: SID_RKEY1<br>Default Value: 0xXXXX_XXXX |
| Bit          | Read/Write | Default | Description                                            |
| 31:0         | R          | x       | Security root key[63:32]                               |

#### 38.3.3. SID Root Key 2 Register

|              |            |         |                                                        |
|--------------|------------|---------|--------------------------------------------------------|
| Offset: 0x08 |            |         | Register Name: SID_RKEY2<br>Default Value: 0xXXXX_XXXX |
| Bit          | Read/Write | Default | Description                                            |
| 31:0         | R          | x       | Security root key[95:64]                               |

### 38.3.4. SID Root Key 3 Register

| Offset: 0x0c |            |         | Register Name: SID_RKEY3<br>Default Value: 0xXXXX_XXXX |
|--------------|------------|---------|--------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                            |
| 31:0         | R          | x       | Security root key[127:96]                              |

### 38.3.5. SID Program Control Register

| Offset: 0x44 |            |         | Register Name: SID_PCTL<br>Default Value: 0x0000_0000                                                       |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                 |
| 31:8         | /          | /       | /                                                                                                           |
| 7:4          | R/W        | 0       | Program index<br>The index value of 32-bits electrical fuses hardware macrocell                             |
| 3:1          | /          | /       | /                                                                                                           |
| 0            | R/W        | 0       | Software program start<br>Write '1' to start software program and automatically clear to '0' after program. |

## 39. GPS Engine

### 39.1. Overview

GPS Tracking is done via a GPS receiver and the satellites in the earth orbit. The signal transmitted from the GPS satellites are received from the antenna. Through the radio frequency (RF) chain the input signal is amplified to proper amplitude and the frequency is converted to a desired output frequency (mid-frequency). An analog-to-digital converter (ADC) is used to digitize the output signal. After the signal is digitized, the GPS baseband will process it.

Acquisition and tracking are the two steps before GPS gets user position.

Acquisition means to find the signal of a certain satellite. There are two PLLs in the baseband processor: one is carrier signal and the other is for PN code. The GPS baseband processor accepts the mid-frequency digitized signals, and then it uses two PLLs to process digitized signal with satellites information one by one. According to the result and other computing, satellites in the sky are being acquired.

The tracking program is used to find the phase transition of the navigation data. From the navigation data phase transition the subframes and navigation data can be obtained. Ephemeris data and pseudoranges can be obtained from the navigation data. The ephemeris data are used to obtain the satellite positions. Finally, the user position can be calculated for the satellite positions and the pseudoranges and is sent to navigation software.

GPS baseband processor features:

|                                        |         |
|----------------------------------------|---------|
| Acquisition sensitivity                | -145dBm |
| Tracking sensitivity                   | -160dbm |
| Cold Start Time to First Fix (CS TTFS) | 45s     |
| Warm Start Time to First Fix (WS TTFS) | 2s      |
| Position accuracy                      | 10m     |

### 39.2. GPS Engine Register List

| Module Name | Base Address |
|-------------|--------------|
| GPS         | 0x01C30000   |

# 40. Port Controller

## 40.1. Overview

The chip has 8 ports for multi-functional input/out pins. They are:

- Port A(PA): 18 input/output port
- Port B(PB): 21input/output port
- Port C(PC): 20 input/output port
- Port D(PD): 28 input/output port
- Port E(PE): 9 input/output port and 3 output port
- Port F(PF): 6 input/output port
- Port G(PG): 11 input/output port and 3 output port

For various system configurations, these ports can be easily configured by software. 32 external PIO interrupt sources are supported and interrupt mode can be configured by software.

## 40.2. Port Configuration Table

| PIO Name | Multiplex Functions |        |          |           |            |         |        |
|----------|---------------------|--------|----------|-----------|------------|---------|--------|
|          | M0                  | M1     | M2       | M3        | M4         | M5      | M6     |
| PA0      | Input               | Output | ERXD3    | TS_CLK    |            | KP_IN0  |        |
| PA1      | Input               | Output | ERXD2    | TS_ERR    |            | KP_IN1  |        |
| PA2      | Input               | Output | ERXD1    | TS_SYNC   |            | KP_IN2  |        |
| PA3      | Input               | Output | ERXD0    | TS_DVLD   |            | KP_IN3  |        |
| PA4      | Input               | Output | ETXD3    | TS_D0     |            | KP_IN4  |        |
| PA5      | Input               | Output | ETXD2    | TS_D1     |            | KP_IN5  |        |
| PA6      | Input               | Output | ETXD1    | TS_D2     |            | KP_IN6  |        |
| PA7      | Input               | Output | ETXD0    | TS_D3     |            | KP_IN7  |        |
| PA8      | Input               | Output | ERXCK    | TS_D4     | UART1_DTR  | KP_OUT0 |        |
| PA9      | Input               | Output | ERXERR   | TS_D5     | UART1_DSR  | KP_OUT1 |        |
| PA10     | Input               | Output | ERXDV    | TS_D6     | UART1_DCD  | KP_OUT2 |        |
| PA11     | Input               | Output | EMDC     | TS_D7     | UART1_RING | KP_OUT3 |        |
| PA10s    | Input               | Output | EMDIO    | UART1_TX  |            | KP_OUT4 |        |
| PA13     | Input               | Output | ETXEN    | UART1_RX  |            | KP_OUT5 |        |
| PA14     | Input               | Output | ETXCK    | UART1_CTS | UART3_TX   | KP_OUT6 |        |
| PA15     | Input               | Output | ECRS     | UART1_RTS | UART3_RX   | KP_OUT7 |        |
| PA16     | Input               | Output | ECOL     | UART2_TX  |            |         |        |
| PA17     | Input               | Output | ETXERR   | UART2_RX  |            |         | EINT31 |
| PB0      | Input               | Output | TWI0_SCK |           |            |         |        |
| PB1      | Input               | Output | TWI0_SDA |           |            |         |        |
| PB2      | Input               | Output | PWM      | /         |            |         | EINT16 |
| PB3      | Input               | Output | IR_TX    |           |            |         | EINT17 |
| PB4      | Input               | Output | IR_RX    |           |            |         | EINT18 |

|      |       |        |           |           |           |  |        |
|------|-------|--------|-----------|-----------|-----------|--|--------|
| PB5  | Input | Output | I2S_MCLK  |           |           |  | EINT19 |
| PB6  | Input | Output | I2S_BCLK  |           |           |  | EINT20 |
| PB7  | Input | Output | I2S_LRCK  |           |           |  | EINT21 |
| PB8  | Input | Output | I2S_DO    |           |           |  | EINT22 |
| PB9  | Input | Output | I2S_DI    | /         |           |  | EINT23 |
| PB10 | Input | Output | SPI2_CS1  | /         |           |  | EINT24 |
| PB11 | Input | Output | SPI2_CS0  | /         |           |  | EINT25 |
| PB12 | Input | Output | SPI2_CLK  | JTAG_CK0  |           |  | EINT26 |
| PB13 | Input | Output | SPI2_MOSI | JTAG_D00  |           |  | EINT27 |
| PB14 | Input | Output | SPI2_MISO | JTAG_D10  |           |  | EINT28 |
| PB15 | Input | Output | TWI1_SCK  |           |           |  |        |
| PB16 | Input | Output | TWI1_SDA  |           |           |  |        |
| PB17 | Input | Output | TWI2_SCK  |           |           |  |        |
| PB18 | Input | Output | TWI2_SDA  |           |           |  |        |
| PB19 | Input | Output | UART0_TX  |           |           |  | EINT29 |
| PB20 | Input | Output | UART0_RX  |           |           |  | EINT30 |
| PC0  | Input | Output | NWE#      | SPI0_MOSI |           |  |        |
| PC1  | Input | Output | NALE      | SPI0_MISO |           |  |        |
| PC2  | Input | Output | NCLE      | SPI0_CLK  |           |  |        |
| PC3  | Input | Output | NCE1      | SPI0_CS0  |           |  |        |
| PC4  | Input | Output | NCE0      |           |           |  |        |
| PC5  | Input | Output | NRE#      |           |           |  |        |
| PC6  | Input | Output | NRB0      | SDC2_CMD  |           |  |        |
| PC7  | Input | Output | NRB1      | SDC2_CLK  |           |  |        |
| PC8  | Input | Output | NDQ0      | SDC2_D0   |           |  |        |
| PC9  | Input | Output | NDQ1      | SDC2_D1   |           |  |        |
| PC10 | Input | Output | NDQ2      | SDC2_D2   |           |  |        |
| PC11 | Input | Output | NDQ3      | SDC2_D3   |           |  |        |
| PC12 | Input | Output | NDQ4      | SDC2_D4   |           |  |        |
| PC13 | Input | Output | NDQ5      | SDC2_D5   |           |  |        |
| PC14 | Input | Output | NDQ6      | SDC2_D6   |           |  |        |
| PC15 | Input | Output | NDQ7      | SDC2_D7   |           |  |        |
| PC16 | Input | Output | NWP       |           | UART3_TX  |  |        |
| PC17 | Input | Output | NCE2      |           | UART3_RX  |  |        |
| PC18 | Input | Output | NCE3      | UART2_TX  | UART3_CTS |  |        |
| PC19 | Input | Output | NDQS      | UART2_RX  | UART3_RTS |  |        |
| PD0  | Input | Output | LCD_D0    |           |           |  |        |
| PD1  | Input | Output | LCD_D1    |           |           |  |        |
| PD2  | Input | Output | LCD_D2    | UART2_TX  |           |  |        |
| PD3  | Input | Output | LCD_D3    | UART2_RX  |           |  |        |
| PD4  | Input | Output | LCD_D4    | UART2_CTS |           |  |        |
| PD5  | Input | Output | LCD_D5    | UART2_RTS |           |  |        |

|      |       |        |           |           |           |  |        |
|------|-------|--------|-----------|-----------|-----------|--|--------|
| PD6  | Input | Output | LCD_D6    | ECRS      |           |  |        |
| PD7  | Input | Output | LCD_D7    | ECOL      |           |  |        |
| PD8  | Input | Output | LCD_D8    |           |           |  |        |
| PD9  | Input | Output | LCD_D9    |           |           |  |        |
| PD10 | Input | Output | LCD_D10   | ERXD0     |           |  |        |
| PD11 | Input | Output | LCD_D11   | ERXD1     |           |  |        |
| PD12 | Input | Output | LCD_D12   | ERXD2     |           |  |        |
| PD13 | Input | Output | LCD_D13   | ERXD3     |           |  |        |
| PD14 | Input | Output | LCD_D14   | ERXCK     |           |  |        |
| PD15 | Input | Output | LCD_D15   | ERXERR    |           |  |        |
| PD16 | Input | Output | LCD_D16   |           |           |  |        |
| PD17 | Input | Output | LCD_D17   |           |           |  |        |
| PD18 | Input | Output | LCD_D18   | ERXDV     |           |  |        |
| PD19 | Input | Output | LCD_D19   | ETXD0     |           |  |        |
| PD20 | Input | Output | LCD_D20   | ETXD1     |           |  |        |
| PD21 | Input | Output | LCD_D21   | ETXD2     |           |  |        |
| PD22 | Input | Output | LCD_D22   | ETXD3     |           |  |        |
| PD23 | Input | Output | LCD_D23   | ETXEN     |           |  |        |
| PD24 | Input | Output | LCD_CLK   | ETXCK     |           |  |        |
| PD25 | Input | Output | LCD_DE    | ETXERR    |           |  |        |
| PD26 | Input | Output | LCD_HSYNC | EMDC      |           |  |        |
| PD27 | Input | Output | LCD_VSYNC | EMDIO     |           |  |        |
| PE0  | Input |        | TS_CLK    | CSI_PCLK  | SPI2_CS0  |  | EINT14 |
| PE1  | Input |        | TS_ERR    | CSI_MCLK  | SPI2_CLK  |  | EINT15 |
| PE2  | Input |        | TS_SYNC   | CSI_HSYNC | SPI2_MOSI |  |        |
| PE3  | Input | Output | TS_DVLD   | CSI_VSYNC | SPI2_MISO |  |        |
| PE4  | Input | Output | TS_D0     | CSI_D0    | SDC2_D0   |  |        |
| PE5  | Input | Output | TS_D1     | CSI_D1    | SDC2_D1   |  |        |
| PE6  | Input | Output | TS_D2     | CSI_D2    | SDC2_D2   |  |        |
| PE7  | Input | Output | TS_D3     | CSI_D3    | SDC2_D3   |  |        |
| PE8  | Input | Output | TS_D4     | CSI_D4    | SDC2_CMD  |  |        |
| PE9  | Input | Output | TS_D5     | CSI_D5    | SDC2_CLK  |  |        |
| PE10 | Input | Output | TS_D6     | CSI_D6    | UART1_TX  |  |        |
| PE11 | Input | Output | TS_D7     | CSI_D7    | UART1_RX  |  |        |
| PF0  | Input | Output | SDC0_D1   |           | JTAG_MS1  |  |        |
| PF1  | Input | Output | SDC0_D0   |           | JTAG_DI1  |  |        |
| PF2  | Input | Output | SDC0_CLK  |           | UART0_TX  |  |        |
| PF3  | Input | Output | SDC0_CMD  |           | JTAG_DO1  |  |        |
| PF4  | Input | Output | SDC0_D3   |           | UART0_RX  |  |        |
| PF5  | Input | Output | SDC0_D2   |           | JTAG_CK1  |  |        |
| PG0  | Input |        | GPS_CLK   |           |           |  | EINT0  |
| PG1  | Input |        | GPS_SIG   |           |           |  | EINT1  |

|      |       |        |           |           |           |           |        |
|------|-------|--------|-----------|-----------|-----------|-----------|--------|
| PG2  | Input |        | GPS_MAG   |           |           |           | EINT2  |
| PG3  | Input | Output | SDC1_CMD  |           | UART1_TX  |           | EINT3  |
| PG4  | Input | Output | SDC1_CLK  |           | UART1_RX  |           | EINT4  |
| PG5  | Input | Output | SDC1_D0   |           | UART1_CTS |           | EINT5  |
| PG6  | Input | Output | SDC1_D1   |           | UART1_RTS | UART2_RTS | EINT6  |
| PG7  | Input | Output | SDC1_D2   |           |           | UART2_TX  | EINT7  |
| PG8  | Input | Output | SDC1_D3   |           |           | UART2_RX  | EINT8  |
| PG9  | Input | Output | SPI1_CS0  | UART3_TX  |           |           | EINT9  |
| PG10 | Input | Output | SPI1_CLK  | UART3_RX  |           |           | EINT10 |
| PG11 | Input | Output | SPI1_MOSI | UART3_CTS |           |           | EINT11 |
| PG12 | Input | Output | SPI1_MISO | UART3_RTS |           |           | EINT12 |
| PG13 | Input | Output | SPI1_CS1  |           |           | UART2_CTS | EINT13 |

### 40.3. Port Register List

| Module Name | Base Address |
|-------------|--------------|
| PIO         | 0x01C20800   |

| Register Name | Offset      | Description                                     |
|---------------|-------------|-------------------------------------------------|
| Pn_CFG0       | n*0x24+0x00 | Port n Configure Register 0 (n from 0 to 6)     |
| Pn_CFG1       | n*0x24+0x04 | Port n Configure Register 1 (n from 0 to 6)     |
| Pn_CFG2       | n*0x24+0x08 | Port n Configure Register 2 (n from 0 to 6)     |
| Pn_CFG3       | n*0x24+0x0C | Port n Configure Register 3 (n from 0 to 6)     |
| Pn_DAT        | n*0x24+0x10 | Port n Data Register (n from 0 to 6)            |
| Pn_DRV0       | n*0x24+0x14 | Port n Multi-Driving Register 0 (n from 0 to 6) |
| Pn_DRV1       | n*0x24+0x18 | Port n Multi-Driving Register 1 (n from 0 to 6) |
| Pn_PUL0       | n*0x24+0x1C | Port n Pull Register 0 (n from 0 to 6)          |
| Pn_PUL1       | n*0x24+0x20 | Port n Pull Register 1 (n from 0 to 6)          |
| PIO_INT_CFG0  | 0x200       | PIO Interrupt Configure Register 0              |
| PIO_INT_CFG1  | 0x204       | PIO Interrupt Configure Register 1              |
| PIO_INT_CFG2  | 0x208       | PIO Interrupt Configure Register 2              |
| PIO_INT_CFG3  | 0x20C       | PIO Interrupt Configure Register 3              |
| PIO_INT_CTL   | 0x210       | PIO Interrupt Control Register                  |
| PIO_INT_STA   | 0x214       | PIO Interrupt Status Register                   |
| PIO_INT_DEB   | 0x218       | PIO Interrupt Debounce Register                 |

### 40.4. Port Register Description

#### 40.4.1. PA Configure Register 0

|              |            |                                                      |
|--------------|------------|------------------------------------------------------|
| Offset: 0x00 |            | Register Name: PA_CFG0<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default Description                                  |

|       |     |   |                                                           |                                                     |
|-------|-----|---|-----------------------------------------------------------|-----------------------------------------------------|
| 31    | /   | / | /                                                         |                                                     |
| 30:28 | R/W | 0 | PA7 Select<br>000: Input<br>010:ETXD0<br>100: /<br>110: / | 001: Output<br>011: TSD3<br>101: KP_IN7<br>111: /   |
| 27    | /   | / | /                                                         |                                                     |
| 26:24 | R/W | 0 | PA6 Select<br>000: Input<br>010:ETXD1<br>100: /<br>110: / | 001: Output<br>011: TSD2<br>101: KP_IN6<br>111: /   |
| 23    | /   | / | /                                                         |                                                     |
| 22:20 | R/W | 0 | PA5 Select<br>000: Input<br>010:ETXD2<br>100: /<br>110: / | 001: Output<br>011: TSD1<br>101: KP_IN5<br>111: /   |
| 19    | /   | / | /                                                         |                                                     |
| 18:16 | R/W | 0 | PA4 Select<br>000: Input<br>010:ETXD3<br>100: /<br>110: / | 001: Output<br>011: TSD0<br>101: KP_IN4<br>111: /   |
| 15    | /   | / | /                                                         |                                                     |
| 14:12 | R/W | 0 | PA3 Select<br>000: Input<br>010:ERXD0<br>100: /<br>110: / | 001: Output<br>011: TSDVLD<br>101: KP_IN3<br>111: / |
| 11    | /   | / | /                                                         |                                                     |
| 10:8  | R/W | 0 | PA2 Select<br>000: Input<br>010:ERXD1<br>100: /<br>110: / | 001: Output<br>011: TSSYNC<br>101: KP_IN2<br>111: / |
| 7     | /   | / | /                                                         |                                                     |
| 6:4   | R/W | 0 | PA1 Select<br>000: Input<br>010:ERXD2<br>100: /<br>110: / | 001: Output<br>011: TSERR<br>101: KP_IN1<br>111: /  |
| 3     | /   | / | /                                                         |                                                     |

|     |     |   |                                                           |                                                    |
|-----|-----|---|-----------------------------------------------------------|----------------------------------------------------|
| 2:0 | R/W | 0 | PA0 Select<br>000: Input<br>010:ERXD3<br>100: /<br>110: / | 001: Output<br>011: TSCLK<br>101: KP_IN0<br>111: / |
|-----|-----|---|-----------------------------------------------------------|----------------------------------------------------|

#### 40.4.2. PA Configure Register 1

| Offset: 0x04 |            |         | Register Name: PA_CFG1<br>Default Value: 0x0000_0000               |                                                         |
|--------------|------------|---------|--------------------------------------------------------------------|---------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                        |                                                         |
| 31           | /          | /       | /                                                                  |                                                         |
| 30:28        | R/W        | 0       | PA15 Select<br>000: Input<br>010:ECRS<br>100: UART3_RX<br>110: /   | 001: Output<br>011: UART1_RTS<br>101: KP_OUT7<br>111: / |
| 27           | /          | /       | /                                                                  |                                                         |
| 26:24        | R/W        | 0       | PA14 Select<br>000: Input<br>010:ETXCK<br>100: UART3_TX<br>110: /  | 001: Output<br>011: UART1_CTS<br>101: KP_OUT6<br>111: / |
| 23           | /          | /       | /                                                                  |                                                         |
| 22:20        | R/W        | 0       | PA13 Select<br>000: Input<br>010:ETXEN<br>100: /<br>110: /         | 001: Output<br>011: UART1_RX<br>101: KP_OUT5<br>111: /  |
| 19           | /          | /       | /                                                                  |                                                         |
| 18:16        | R/W        | 0       | PA12 Select<br>000: Input<br>010:EMDIO<br>100: /<br>110: /         | 001: Output<br>011: UART1_TX<br>101: KP_OUT4<br>111: /  |
| 15           | /          | /       | /                                                                  |                                                         |
| 14:12        | R/W        | 0       | PA11 Select<br>000: Input<br>010:EMDC<br>100: UART1_RING<br>110: / | 001: Output<br>011: TSD7<br>101: KP_OUT3<br>111: /      |
| 11           | /          | /       | /                                                                  |                                                         |
| 10:8         | R/W        | 0       | PA10 Select<br>000: Input                                          | 001: Output                                             |

|     |     |   |                                                                    |                                                    |
|-----|-----|---|--------------------------------------------------------------------|----------------------------------------------------|
|     |     |   | 010:ERXDV<br>100: UART1_DCD<br>110: /                              | 011: TSD6<br>101: KP_OUT2<br>111: /                |
| 7   | /   | / | /                                                                  |                                                    |
| 6:4 | R/W | 0 | PA9 Select<br>000: Input<br>010:ERXERR<br>100: UART1_DSR<br>110: / | 001: Output<br>011: TSD5<br>101: KP_OUT1<br>111: / |
| 3   | /   | / | /                                                                  |                                                    |
| 2:0 | R/W | 0 | PA8 Select<br>000: Input<br>010:ERXCK<br>100: UART1_DTR<br>110: /  | 001: Output<br>011: TSD4<br>101: KP_OUT0<br>111: / |

#### 40.4.3. PA Configure Register 2

|              |            |         |                                                                  |
|--------------|------------|---------|------------------------------------------------------------------|
| Offset: 0x08 |            |         | Register Name: PA_CFG2<br>Default Value: 0x0000_0000             |
| Bit          | Read/Write | Default | Description                                                      |
| 31:7         | /          | /       | /                                                                |
| 6:4          | R/W        | 0       | PA17 Select<br>000: Input<br>010:ETXERR<br>100: /<br>110: EINT31 |
| 3            | /          | /       | /                                                                |
| 2:0          | R/W        | 0       | PA16 Select<br>000: Input<br>010:ECOL<br>100: /<br>110: /        |

#### 40.4.4. PA Configure Register 3

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0x0C |            |         | Register Name: PA_CFG3<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.5. PA Data Register

|              |            |         |                                                     |
|--------------|------------|---------|-----------------------------------------------------|
| Offset: 0x10 |            |         | Register Name: PA_DAT<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                         |

|       |     |   |                                                                                                                                                                                                                                                                                                        |
|-------|-----|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:18 | /   | / | /                                                                                                                                                                                                                                                                                                      |
| 17:0  | R/W | 0 | 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. |

#### 40.4.6. PA Multi-Driving Register 0

| Offset: 0x14          |            |         | Register Name: PA_DRV0<br>Default Value: 0x5555_5555                                                                              |
|-----------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                                       |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x1     | PA[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.7. PA Multi-Driving Register 1

| Offset: 0x18         |            |         | Register Name: PA_DRV1<br>Default Value: 0x0000_0005                                                                               |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                        |
| 31:4                 | /          | /       | /                                                                                                                                  |
| [2i+1:2i]<br>(i=0~1) | R/W        | 0x1     | PA[n] Multi-Driving Select (n = 16~17)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.8. PA Pull Register 0

| Offset: 0x1C          |            |         | Register Name: PA_PULL0<br>Default Value: 0x0000_0000                                                                            |
|-----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                                      |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x0     | PA[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 40.4.9. PA Pull Register 1

| Offset: 0x20         |            |         | Register Name: PA_PULL1<br>Default Value: 0x0000_0000                                                                                    |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                              |
| 31:4                 | /          | /       | /                                                                                                                                        |
| [2i+1:2i]<br>(i=0~1) | R/W        | 0x0     | PA[n] Pull-up/down Select (n = 16~17)<br>00: Pull-up/down disable    01: Pull-up enable<br>10: Pull-down                    11: Reserved |

#### 40.4.10. PB Configure Register 0

| Offset: 0x24 |            |         | Register Name: PB_CFG0<br>Default Value: 0x0000_0000                                                |
|--------------|------------|---------|-----------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                         |
| 31           | /          | /       | /                                                                                                   |
|              |            |         | PB7 Select<br>000: Input 001: Output<br>010: I2S_LRCK 011: /<br>100: / 101: /<br>110: EINT21 111: / |
| 30:28        | R/W        | 0       |                                                                                                     |
| 27           | /          | /       | /                                                                                                   |
|              |            |         | PB6 Select<br>000: Input 001: Output<br>010: I2C_BCLK 011: /<br>100: / 101: /<br>110: EINT20 111: / |
| 26:24        | R/W        | 0       |                                                                                                     |
| 23           | /          | /       | /                                                                                                   |
|              |            |         | PB5 Select<br>000: Input 001: Output<br>010: I2C_MCLK 011: /<br>100: / 101: /<br>110: EINT19 111: / |
| 22:20        | R/W        | 0       |                                                                                                     |
| 19           | /          | /       | /                                                                                                   |
|              |            |         | PB4 Select<br>000: Input 001: Output<br>010: IR_RX 011: /<br>100: / 101: /<br>110: EINT18 111: /    |
| 18:16        | R/W        | 0       |                                                                                                     |
| 15           | /          | /       | /                                                                                                   |
|              |            |         | PB3 Select<br>000: Input 001: Output<br>010: IR_TX 011: /<br>100: / 101: /<br>110: EINT17 111: /    |
| 14:12        | R/W        | 0       |                                                                                                     |
| 11           | /          | /       | /                                                                                                   |
|              |            |         | PB2 Select<br>000: Input 001: Output<br>010: PWM 011: /<br>100: / 101: /<br>110: EINT16 111: /      |
| 10:8         | R/W        | 0       |                                                                                                     |
| 7            | /          | /       | /                                                                                                   |
| 6:4          | R/W        | 0       | PB1 Select<br>000: Input 001: Output                                                                |

|     |     |   |                                                            |                                        |
|-----|-----|---|------------------------------------------------------------|----------------------------------------|
|     |     |   | 010:TWI0_SDA<br>100:/<br>110:/                             | 011:/<br>101:/<br>111:/                |
| 3   | /   | / | /                                                          |                                        |
| 2:0 | R/W | 0 | PB0 Select<br>000: Input<br>010:TWI0_SCK<br>100:/<br>110:/ | 001: Output<br>011:/<br>101:/<br>111:/ |

#### 40.4.11. PB Configure Register 1

| Offset: 0x28 |            |         | Register Name: PB_CFG1<br>Default Value: 0x0000_0000               |                                                |
|--------------|------------|---------|--------------------------------------------------------------------|------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                        |                                                |
| 31           | /          | /       | /                                                                  |                                                |
| 30:28        | R/W        | 0       | PB15 Select<br>000: Input<br>010:TWI1_SCK<br>100:/<br>110:/        | 001: Output<br>011:/<br>101:/<br>111:/         |
| 27           | /          | /       | /                                                                  |                                                |
| 26:24        | R/W        | 0       | PB14 Select<br>000: Input<br>010:SPI2_MISO<br>100:/<br>110: EINT28 | 001: Output<br>011: JTAG_DIO<br>101:/<br>111:/ |
| 23           | /          | /       | /                                                                  |                                                |
| 22:20        | R/W        | 0       | PB13 Select<br>000: Input<br>010:SPI2_MOSI<br>100:/<br>110: EINT27 | 001: Output<br>011: JTAG_D00<br>101:/<br>111:/ |
| 19           | /          | /       | /                                                                  |                                                |
| 18:16        | R/W        | 0       | PB12 Select<br>000: Input<br>010:SPI2_CLK<br>100:/<br>110: EINT26  | 001: Output<br>011: JTAG_CK0<br>101:/<br>111:/ |
| 15           | /          | /       | /                                                                  |                                                |
| 14:12        | R/W        | 0       | PB11 Select<br>000: Input<br>010:SPI2_CS0<br>100:/                 | 001: Output<br>011:/<br>101:/                  |

|      |     |   |                                                                     |                                           |
|------|-----|---|---------------------------------------------------------------------|-------------------------------------------|
|      |     |   | 110: EINT25                                                         | 111: /                                    |
| 11   | /   | / | /                                                                   |                                           |
|      |     |   | PB10 Select<br>000: Input<br>010: SPI2_CS1<br>100: /<br>110: EINT24 | 001: Output<br>011: /<br>101: /<br>111: / |
| 10:8 | R/W | 0 |                                                                     |                                           |
| 7    | /   | / | /                                                                   |                                           |
|      |     |   | PB9 Select<br>000: Input<br>010: I2S_DI<br>100: /<br>110: EINT23    | 001: Output<br>011: /<br>101: /<br>111: / |
| 6:4  | R/W | 0 |                                                                     |                                           |
| 3    | /   | / | /                                                                   |                                           |
|      |     |   | PB8 Select<br>000: Input<br>010: I2S_DO<br>100: /<br>110: EINT22    | 001: Output<br>011: /<br>101: /<br>111: / |
| 2:0  | R/W | 0 |                                                                     |                                           |

#### 40.4.12. PB Configure Register 2

| Offset: 0x2C |            |         | Register Name: PB_CFG2<br>Default Value: 0x0000_0000                |
|--------------|------------|---------|---------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                         |
| 31:20        | /          | /       | /                                                                   |
| 19           | /          | /       | /                                                                   |
|              |            |         | PB20 Select<br>000: Input<br>010: UART0_RX<br>100: /<br>110: EINT30 |
| 18:16        | R/W        | 0       | 001: Output<br>011: /<br>101: /<br>111: /                           |
| 15           | /          | /       | /                                                                   |
|              |            |         | PB19 Select<br>000: Input<br>010: UART0_TX<br>100: /<br>110: EINT29 |
| 14:12        | R/W        | 0       | 001: Output<br>011: /<br>101: /<br>111: /                           |
| 11           | /          | /       | /                                                                   |
|              |            |         | PB18 Select<br>000: Input<br>010: TWI2_SDA<br>100: /<br>110: /      |
| 10:8         | R/W        | 0       | 001: Output<br>011: /<br>101: /<br>111: /                           |

|     |     |   |                                                                                                 |
|-----|-----|---|-------------------------------------------------------------------------------------------------|
| 7   | /   | / | /                                                                                               |
| 6:4 | R/W | 0 | PB17 Select<br>000: Input 001: Output<br>010: TWI2_SCK 011: /<br>100: / 101: /<br>110: / 111: / |
| 3   | /   | / | /                                                                                               |
| 2:0 | R/W | 0 | PB16 Select<br>000: Input 001: Output<br>010: TWI1_SDA 011: /<br>100: / 101: /<br>110: / 111: / |

#### 40.4.13. PB Configure Register 3

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0x30 |            |         | Register Name: PB_CFG3<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.14. PB Data Register

|              |            |         |                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x34 |            |         | Register Name: PB_DAT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                    |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                            |
| 31:24        | /          | /       | /                                                                                                                                                                                                                                                                                                      |
| 23:0         | R/W        | 0       | 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. |

#### 40.4.15. PB Multi-Driving Register 0

|                       |            |         |                                                                                             |
|-----------------------|------------|---------|---------------------------------------------------------------------------------------------|
| Offset: 0x38          |            |         | Register Name: PB_DRV0<br>Default Value: 0x5555_5555                                        |
| Bit                   | Read/Write | Default | Description                                                                                 |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x1     | PB[n] Multi-Driving Select (n = 0~15)<br>00: Level 0 01: Level 1<br>10: Level 2 11: Level 3 |

#### 40.4.16. PB Multi-Driving Register 1

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0x3C |            |         | Register Name: PB_DRV1<br>Default Value: 0x0000_0155 |
| Bit          | Read/Write | Default | Description                                          |

|                      |     |     |                                                                                                                                    |
|----------------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------|
| 31:10                | /   | /   | /                                                                                                                                  |
| [2i+1:2i]<br>(i=0~4) | R/W | 0x1 | PB[n] Multi-Driving Select (n = 16~20)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.17. PB Pull Register 0

| Offset: 0x40          |            |         | Register Name: PB_PULL0<br>Default Value: 0x0000_0000                                                                            |
|-----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                                      |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x0     | PB[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 40.4.18. PB Pull Register 1

| Offset: 0x44         |            |         | Register Name: PB_PULL1<br>Default Value: 0x0000_0000                                                                                    |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                              |
| 31:10                | /          | /       | /                                                                                                                                        |
| [2i+1:2i]<br>(i=0~4) | R/W        | 0x0     | PB[n] Pull-up/down Select (n = 16~20)<br>00: Pull-up/down disable    01: Pull-up enable<br>10: Pull-down                    11: Reserved |

#### 40.4.19. PC Configure Register 0

| Offset: 0x48 |            |         | Register Name: PC_CFG0<br>Default Value: 0x0000_0000                                                                                                                                 |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                                                                          |
| 31           | /          | /       | /                                                                                                                                                                                    |
| 30:28        | R/W        | 0       | PC7 Select<br>000: Input                    001: Output<br>010:NRB1                    011: SDC2_CLK<br>100: /                        101: /<br>110: /                        111: / |
| 27           | /          | /       | /                                                                                                                                                                                    |
| 26:24        | R/W        | 0       | PC6 Select<br>000: Input                    001: Output<br>010:NRB0                    011: SDC2_CMD<br>100: /                        101: /<br>110: /                        111: / |
| 23           | /          | /       | /                                                                                                                                                                                    |
| 22:20        | R/W        | 0       | PC5 Select<br>000: Input                    001: Output<br>010:NRE#                    011: /<br>100: /                        101: /                                                |

|       |     |   |                                                          |                                                   |
|-------|-----|---|----------------------------------------------------------|---------------------------------------------------|
|       |     |   | 110: /                                                   | 111: /                                            |
| 19    | /   | / | /                                                        |                                                   |
|       |     |   | PC4 Select<br>000: Input<br>010:NCE0<br>100: /<br>110: / | 001: Output<br>011: /<br>101: /<br>111: /         |
| 18:16 | R/W | 0 |                                                          |                                                   |
| 15    | /   | / | /                                                        |                                                   |
|       |     |   | PC3 Select<br>000: Input<br>010:NCE1<br>100: /<br>110: / | 001: Output<br>011: SPI0_CS0<br>101: /<br>111: /  |
| 14:12 | R/W | 0 |                                                          |                                                   |
| 11    | /   | / | /                                                        |                                                   |
|       |     |   | PC2 Select<br>000: Input<br>010:NCLE<br>100: /<br>110: / | 001: Output<br>011: SPI0_CLK<br>101: /<br>111: /  |
| 10:8  | R/W | 0 |                                                          |                                                   |
| 7     | /   | / | /                                                        |                                                   |
|       |     |   | PC1 Select<br>000: Input<br>010:NALE<br>100: /<br>110: / | 001: Output<br>011: SPI0_MISO<br>101: /<br>111: / |
| 6:4   | R/W | 0 |                                                          |                                                   |
| 3     | /   | / | /                                                        |                                                   |
|       |     |   | PC0 Select<br>000: Input<br>010:NWE#<br>100: /<br>110: / | 001: Output<br>011: SPI0_MOSI<br>101: /<br>111: / |
| 2:0   | R/W | 0 |                                                          |                                                   |

#### 40.4.20. PC Configure Register 1

| Offset: 0x4C |            |         | Register Name: PC_CFG1<br>Default Value: 0x0000_0000      |
|--------------|------------|---------|-----------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                               |
| 31           | /          | /       | /                                                         |
|              |            |         | PC15 Select<br>000: Input<br>010:NDQ7<br>100: /<br>110: / |
| 30:28        | R/W        | 0       |                                                           |
| 27           | /          | /       | /                                                         |

|       |     |   |             |              |
|-------|-----|---|-------------|--------------|
|       |     |   | PC14 Select |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ6    | 011: SDC2_D6 |
|       |     |   | 100: /      | 101: /       |
| 26:24 | R/W | 0 | 110: /      | 111: /       |
| 23    | /   | / | /           |              |
|       |     |   | PC13 Select |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ5    | 011: SDC2_D5 |
|       |     |   | 100: /      | 101: /       |
| 22:20 | R/W | 0 | 110: /      | 111: /       |
| 19    | /   | / | /           |              |
|       |     |   | PC12 Select |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ4    | 011: SDC2_D4 |
|       |     |   | 100: /      | 101: /       |
| 18:16 | R/W | 0 | 110: /      | 111: /       |
| 15    | /   | / | /           |              |
|       |     |   | PC11 Select |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ3    | 011: SDC2_D3 |
|       |     |   | 100: /      | 101: /       |
| 14:12 | R/W | 0 | 110: /      | 111: /       |
| 11    | /   | / | /           |              |
|       |     |   | PC10 Select |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ2    | 011: SDC2_D2 |
|       |     |   | 100: /      | 101: /       |
| 10:8  | R/W | 0 | 110: /      | 111: /       |
| 7     | /   | / | /           |              |
|       |     |   | PC9 Select  |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ1    | 011: SDC2_D1 |
|       |     |   | 100: /      | 101: /       |
| 6:4   | R/W | 0 | 110: /      | 111: /       |
| 3     | /   | / | /           |              |
|       |     |   | PC8 Select  |              |
|       |     |   | 000: Input  | 001: Output  |
|       |     |   | 010:NDQ0    | 011: SDC2_D0 |
|       |     |   | 100: /      | 101: /       |
| 2:0   | R/W | 0 | 110: /      | 111: /       |

#### 40.4.21. PC Configure Register 2

| Offset: 0x50 |            |         | Register Name: PC_CFG2<br>Default Value: 0x0000_0000                                                       |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                |
| 31:16        | /          | /       | /                                                                                                          |
| 15           | /          | /       | /                                                                                                          |
| 14:12        | R/W        | 0       | PC19 Select<br>000: Input 001: Output<br>010: NDQS 011: UART2_RX<br>100: UART3_RTS 101: /<br>110: / 111: / |
| 11           | /          | /       | /                                                                                                          |
| 10:8         | R/W        | 0       | PC18 Select<br>000: Input 001: Output<br>010: NCE3 011: UART2_TX<br>100: UART3_CTS 101: /<br>110: / 111: / |
| 7            | /          | /       | /                                                                                                          |
| 6:4          | R/W        | 0       | PC17 Select<br>000: Input 001: Output<br>010: NCE2 011: /<br>100: UART3_RX 101: /<br>110: / 111: /         |
| 3            | /          | /       | /                                                                                                          |
| 2:0          | R/W        | 0       | PC16 Select<br>000: Input 001: Output<br>010: NWP 011: /<br>100: UART3_TX 101: /<br>110: / 111: /          |

#### 40.4.22. PC Configure Register 3

| Offset: 0x54 |            |         | Register Name: PC_CFG3<br>Default Value: 0x0000_0000 |
|--------------|------------|---------|------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.23. PC Data Register

| Offset: 0x58 |            |         | Register Name: PC_DAT<br>Default Value: 0x0000_0000                  |
|--------------|------------|---------|----------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                          |
| 31:24        | /          | /       | /                                                                    |
| 23:0         | R/W        | 0       | 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. |
|--|--|--|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### 40.4.24. PC Multi-Driving Register 0

| Offset: 0x5C          |            |         | Register Name: PC_DRV0<br>Default Value: 0x5555_5555                                                                              |
|-----------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                                       |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x1     | PC[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.25. PC Multi-Driving Register 1

| Offset: 0x60 |            |         | Register Name: PC_DRV1<br>Default Value: 0x0000_0055 |
|--------------|------------|---------|------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                          |
| 31:8         | /          | /       | /                                                    |

  

| [2i+1:2i]<br>(i=0~3) |            |         | PC[n] Multi-Driving Select (n = 16~19)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                        |
| 31:8                 | /          | /       | /                                                                                                                                  |

#### 40.4.26. PC Pull Register 0

| Offset: 0x64          |            |             | Register Name: PC_PULL0<br>Default Value: 0x0000_5140                                                                            |
|-----------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default     | Description                                                                                                                      |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x0000_5140 | PC[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 40.4.27. PC Pull Register 1

| Offset: 0x68 |            |         | Register Name: PC_PULL1<br>Default Value: 0x0000_0016 |
|--------------|------------|---------|-------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                           |
| 31:8         | /          | /       | /                                                     |

  

| [2i+1:2i]<br>(i=0~3) |            |         | PC[n] Pull-up/down Select (n = 16~19)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |
|----------------------|------------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                       |
| 31:8                 | /          | /       | /                                                                                                                                 |

#### 40.4.28. PD Configure Register 0

|              |                                                      |
|--------------|------------------------------------------------------|
| Offset: 0x6C | Register Name: PD_CFG0<br>Default Value: 0x0000_0000 |
|--------------|------------------------------------------------------|

| Bit   | Read/Write | Default | Description                                                |
|-------|------------|---------|------------------------------------------------------------|
| 31    | /          | /       | /                                                          |
| 30:28 | R/W        | 0       | PD7 Select<br>000: Input<br>010:LCD_D7<br>100: /<br>110: / |
| 27    | /          | /       | /                                                          |
| 26:24 | R/W        | 0       | PD6 Select<br>000: Input<br>010:LCD_D6<br>100: /<br>110: / |
| 23    | /          | /       | /                                                          |
| 22:20 | R/W        | 0       | PD5 Select<br>000: Input<br>010:LCD_D5<br>100: /<br>110: / |
| 19    | /          | /       | /                                                          |
| 18:16 | R/W        | 0       | PD4 Select<br>000: Input<br>010:LCD_D4<br>100: /<br>110: / |
| 15    | /          | /       | /                                                          |
| 14:12 | R/W        | 0       | PD3 Select<br>000: Input<br>010:LCD_D3<br>100: /<br>110: / |
| 11    | /          | /       | /                                                          |
| 10:8  | R/W        | 0       | PD2 Select<br>000: Input<br>010:LCD_D2<br>100: /<br>110: / |
| 7     | /          | /       | /                                                          |
| 6:4   | R/W        | 0       | PD1 Select<br>000: Input<br>010:LCD_D1<br>100: /<br>110: / |

|     |     |   |                                                                                             |
|-----|-----|---|---------------------------------------------------------------------------------------------|
| 3   | /   | / | /                                                                                           |
| 2:0 | R/W | 0 | PD0 Select<br>000: Input 001: Output<br>010:LCD_D0 011: /<br>100: / 101: /<br>110: / 111: / |

#### 40.4.29. PD Configure Register 1

| Offset: 0x70 |            |         | Register Name: PD_CFG1<br>Default Value: 0x0000_0000                                               |
|--------------|------------|---------|----------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                        |
| 31           | /          | /       | /                                                                                                  |
| 30:28        | R/W        | 0       | PD15 Select<br>000: Input 001: Output<br>010:LCD_D15 011: ERXERR<br>100: / 101: /<br>110: / 111: / |
| 27           | /          | /       | /                                                                                                  |
| 26:24        | R/W        | 0       | PD14 Select<br>000: Input 001: Output<br>010:LCD_D14 011: ERXCK<br>100: / 101: /<br>110: / 111: /  |
| 23           | /          | /       | /                                                                                                  |
| 22:20        | R/W        | 0       | PD13 Select<br>000: Input 001: Output<br>010:LCD_D13 011: ERXD3<br>100: / 101: /<br>110: / 111: /  |
| 19           | /          | /       | /                                                                                                  |
| 18:16        | R/W        | 0       | PD12 Select<br>000: Input 001: Output<br>010:LCD_D12 011: ERXD2<br>100: / 101: /<br>110: / 111: /  |
| 15           | /          | /       | /                                                                                                  |
| 14:12        | R/W        | 0       | PD11 Select<br>000: Input 001: Output<br>010:LCD_D11 011: ERXD1<br>100: / 101: /<br>110: / 111: /  |
| 11           | /          | /       | /                                                                                                  |
| 10:8         | R/W        | 0       | PD10 Select                                                                                        |

|     |     |   |                                                            |                                               |
|-----|-----|---|------------------------------------------------------------|-----------------------------------------------|
|     |     |   | 000: Input<br>010:LCD_D10<br>100: /<br>110: /              | 001: Output<br>011: ERXD0<br>101: /<br>111: / |
| 7   | /   | / | /                                                          |                                               |
| 6:4 | R/W | 0 | PD9 Select<br>000: Input<br>010:LCD_D9<br>100: /<br>110: / | 001: Output<br>011: /<br>101: /<br>111: /     |
| 3   | /   | / | /                                                          |                                               |
| 2:0 | R/W | 0 | PD8 Select<br>000: Input<br>010:LCD_D8<br>100: /<br>110: / | 001: Output<br>011: /<br>101: /<br>111: /     |

#### 40.4.30. PD Configure Register 2

| Offset: 0x74 |            |         | Register Name: PD_CFG2<br>Default Value: 0x0000_0000         |
|--------------|------------|---------|--------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                  |
| 31           | /          | /       | /                                                            |
| 30:28        | R/W        | 0       | PD23 Select<br>000: Input<br>010:LCD_D23<br>100: /<br>110: / |
| 27           | /          | /       | /                                                            |
| 26:24        | R/W        | 0       | PD22 Select<br>000: Input<br>010:LCD_D22<br>100: /<br>110: / |
| 23           | /          | /       | /                                                            |
| 22:20        | R/W        | 0       | PD21 Select<br>000: Input<br>010:LCD_D21<br>100: /<br>110: / |
| 19           | /          | /       | /                                                            |
| 18:16        | R/W        | 0       | PD20 Select<br>000: Input<br>010:LCD_D20                     |
|              |            |         | 001: Output<br>011: ETXD3<br>101: /<br>111: /                |

|       |     |   |                                                              |                                               |
|-------|-----|---|--------------------------------------------------------------|-----------------------------------------------|
|       |     |   | 100: /<br>110: /                                             | 101: /<br>111: /                              |
| 15    | /   | / | /                                                            |                                               |
| 14:12 | R/W | 0 | PD19 Select<br>000: Input<br>010:LCD_D19<br>100: /<br>110: / | 001: Output<br>011: ETXD0<br>101: /<br>111: / |
| 11    | /   | / | /                                                            |                                               |
| 10:8  | R/W | 0 | PD18 Select<br>000: Input<br>010:LCD_D18<br>100: /<br>110: / | 001: Output<br>011: ERXDV<br>101: /<br>111: / |
| 7     | /   | / | /                                                            |                                               |
| 6:4   | R/W | 0 | PD17 Select<br>000: Input<br>010:LCD_D17<br>100: /<br>110: / | 001: Output<br>011: /<br>101: /<br>111: /     |
| 3     | /   | / | /                                                            |                                               |
| 2:0   | R/W | 0 | PD16 Select<br>000: Input<br>010:LCD_D16<br>100: /<br>110: / | 001: Output<br>011: /<br>101: /<br>111: /     |

#### 40.4.31. PD Configure Register 3

| Offset: 0x78 |            |         | Register Name: PD_CFG3<br>Default Value: 0x0000_0000           |
|--------------|------------|---------|----------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                    |
| 31:16        | /          | /       | /                                                              |
| 15           | /          | /       | /                                                              |
| 14:12        | R/W        | 0       | PD27 Select<br>000: Input<br>010:LCD_VSYNC<br>100: /<br>110: / |
| 11           | /          | /       | /                                                              |
| 10:8         | R/W        | 0       | PD26 Select<br>000: Input<br>010:LCD_HSYNC<br>100: /           |

|     |     |   |                                                              |                                                |
|-----|-----|---|--------------------------------------------------------------|------------------------------------------------|
|     |     |   | 110: /                                                       | 111: /                                         |
| 7   | /   | / | /                                                            |                                                |
| 6:4 | R/W | 0 | PD25 Select<br>000: Input<br>010:LCD_DE<br>100: /<br>110: /  | 001: Output<br>011: ETXERR<br>101: /<br>111: / |
| 3   | /   | / | /                                                            |                                                |
| 2:0 | R/W | 0 | PD24 Select<br>000: Input<br>010:LCD_CLK<br>100: /<br>110: / | 001: Output<br>011: ETXCK<br>101: /<br>111: /  |

#### 40.4.32. PD Data Register

|              |            |         |                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x7C |            |         | Register Name: PD_DAT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                    |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                            |
| 31:28        | /          | /       | /                                                                                                                                                                                                                                                                                                      |
| 27:0         | R/W        | 0       | 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. |

#### 40.4.33. PD Multi-Driving Register 0

|                       |            |         |                                                                                                                               |
|-----------------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x80          |            |         | Register Name: PD_DRV0<br>Default Value: 0x5555_5555                                                                          |
| Bit                   | Read/Write | Default | Description                                                                                                                   |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x1     | PD[n] Multi-Driving Select (n = 0~15)<br>00: Level 0                  01: Level 1<br>10: Level 2                  11: Level 3 |

#### 40.4.34. PD Multi-Driving Register 1

|                       |            |         |                                                                                                                                |
|-----------------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x84          |            |         | Register Name: PD_DRV1<br>Default Value: 0x0055_5555                                                                           |
| Bit                   | Read/Write | Default | Description                                                                                                                    |
| 31:24                 | /          | /       | /                                                                                                                              |
| [2i+1:2i]<br>(i=0~11) | R/W        | 0x1     | PD[n] Multi-Driving Select (n = 16~27)<br>00: Level 0                  01: Level 1<br>10: Level 2                  11: Level 3 |

#### 40.4.35. PD Pull Register 0

| Offset: 0x88          |            |         | Register Name: PD_PULL0<br>Default Value: 0x0000_0000                                                      |
|-----------------------|------------|---------|------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                |
| [2i+1:2i]<br>(i=0~15) | R/W        | 0x0     | PD[n] Pull-up/down Select (n = 0~15)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### 40.4.36. PD Pull Register 1

| Offset: 0x8C          |            |         | Register Name: PD_PULL1<br>Default Value: 0x0000_0000                                                              |
|-----------------------|------------|---------|--------------------------------------------------------------------------------------------------------------------|
| Bit                   | Read/Write | Default | Description                                                                                                        |
| 31:24                 | /          | /       | /                                                                                                                  |
| [2i+1:2i]<br>(i=0~11) | R/W        | 0x0     | PD[n] Pull-up/down Select (n = 16~27)<br>00: Pull-up/down disable 01: Pull-up enable<br>10: Pull-down 11: Reserved |

#### 40.4.37. PE Configure Register 0

| Offset: 0x90 |            |         | Register Name: PE_CFG0<br>Default Value: 0x0000_0000                                                   |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                            |
| 31           | /          | /       | /                                                                                                      |
| 30:28        | R/W        | 0       | PE7 Select<br>000: Input 001: Output<br>010: TS_D3 011: CSI_D3<br>100: SDC2_D3 101: /<br>110: / 111: / |
| 27           | /          | /       | /                                                                                                      |
| 26:24        | R/W        | 0       | PE6 Select<br>000: Input 001: Output<br>010: TS_D2 011: CSI_D2<br>100: SDC2_D2 101: /<br>110: / 111: / |
| 23           | /          | /       | /                                                                                                      |
| 22:20        | R/W        | 0       | PE5 Select<br>000: Input 001: Output<br>010: TS_D1 011: CSI_D1<br>100: SDC2_D1 101: /<br>110: / 111: / |
| 19           | /          | /       | /                                                                                                      |
| 18:16        | R/W        | 0       | PE4 Select<br>000: Input 001: Output                                                                   |

|       |     |   |                                                                        |                                                     |
|-------|-----|---|------------------------------------------------------------------------|-----------------------------------------------------|
|       |     |   | 010:TS_D0<br>100: SDC2_D0<br>110: /                                    | 011: CSI_D0<br>101: /<br>111: /                     |
| 15    | /   | / | /                                                                      |                                                     |
| 14:12 | R/W | 0 | PE3 Select<br>000: Input<br>010:TS_DVLD<br>100: SPI2_MISO<br>110: /    | 001: Output<br>011: CSI_VSYNC<br>101: /<br>111: /   |
| 11    | /   | / | /                                                                      |                                                     |
| 10:8  | R/W | 0 | PE2 Select<br>000: Input<br>010:TS_SYNC<br>100: SPI2_MOSI<br>110: /    | 001: Reserved<br>011: CSI_HSYNC<br>101: /<br>111: / |
| 7     | /   | / | /                                                                      |                                                     |
| 6:4   | R/W | 0 | PE1 Select<br>000: Input<br>010:TS_ERR<br>100: SPI2_CLK<br>110: EINT15 | 001: Reserved<br>011: CSI_MCLK<br>101: /<br>111: /  |
| 3     | /   | / | /                                                                      |                                                     |
| 2:0   | R/W | 0 | PE0 Select<br>000: Input<br>010:TS_CLK<br>100: SPI2_CS0<br>110: EINT14 | 001: Reserved<br>011: CSI_PCLK<br>101: /<br>111: /  |

#### 40.4.38. PE Configure Register 1

|              |            |         |                                                                   |
|--------------|------------|---------|-------------------------------------------------------------------|
| Offset: 0x94 |            |         | Register Name: PE_CFG1<br>Default Value: 0x0000_0000              |
| Bit          | Read/Write | Default | Description                                                       |
| 31:16        | /          | /       | /                                                                 |
| 15           | /          | /       | /                                                                 |
| 14:12        | R/W        | 0       | PE11 Select<br>000: Input<br>010:TS_D7<br>100: UART1_RX<br>110: / |
| 11           | /          | /       | /                                                                 |
| 10:8         | R/W        | 0       | PE10 Select<br>000: Input<br>010:TS_D6                            |

|     |     |   |                                                                   |                                                |
|-----|-----|---|-------------------------------------------------------------------|------------------------------------------------|
|     |     |   | 100: UART1_TX<br>110: /                                           | 101: /<br>111: /                               |
| 7   | /   | / | /                                                                 |                                                |
| 6:4 | R/W | 0 | PE9 Select<br>000: Input<br>010: TS_D5<br>100: SDC2_CLK<br>110: / | 001: Output<br>011: CSI_D5<br>101: /<br>111: / |
| 3   | /   | / | /                                                                 |                                                |
| 2:0 | R/W | 0 | PE8 Select<br>000: Input<br>010: TS_D4<br>100: SDC2_CMD<br>110: / | 001: Output<br>011: CSI_D4<br>101: /<br>111: / |

#### 40.4.39. PE Configure Register 2

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0x98 |            |         | Register Name: PE_CFG2<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.40. PE Configure Register 3

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0x9C |            |         | Register Name: PE_CFG3<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.41. PE Data Register

|              |            |         |                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xA0 |            |         | Register Name: PE_DAT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                    |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                            |
| 31:28        | /          | /       | /                                                                                                                                                                                                                                                                                                      |
| 27:0         | R/W        | 0       | 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. |

#### 40.4.42. PE Multi-Driving Register 0

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xA4 |            |         | Register Name: PE_DRV0<br>Default Value: 0x0055_5555 |
| Bit          | Read/Write | Default | Description                                          |

|                       |     |     |                                                                                                                                   |
|-----------------------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:24                 | /   | /   | /                                                                                                                                 |
| [2i+1:2i]<br>(i=0~11) | R/W | 0x1 | PE[n] Multi-Driving Select (n = 0~11)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.43. PE Multi-Driving Register 1

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xA8 |            |         | Register Name: PE_DRV1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.44. PE Pull Register 0

|                       |            |         |                                                                                                                                  |
|-----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xAC          |            |         | Register Name: PE_PULL0<br>Default Value: 0x0000_0000                                                                            |
| Bit                   | Read/Write | Default | Description                                                                                                                      |
| 31:24                 | /          | /       | /                                                                                                                                |
| [2i+1:2i]<br>(i=0~11) | R/W        | 0x0     | PE[n] Pull-up/down Select (n = 0~11)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |

#### 40.4.45. PE Pull Register 1

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0xB0 |            |         | Register Name: PE_PULL1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                           |
| 31:0         | /          | /       | /                                                     |

#### 40.4.46. PF Configure Register 0

|              |            |         |                                                                                                                                                                              |
|--------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xB4 |            |         | Register Name: PF_CFG0<br>Default Value: 0x0040_4044                                                                                                                         |
| Bit          | Read/Write | Default | Description                                                                                                                                                                  |
| 31:24        | /          | /       | /                                                                                                                                                                            |
| 23           | /          | /       | /                                                                                                                                                                            |
| 22:20        | R/W        | 0x4     | PF5 Select<br>000: Input                    001: Output<br>010: SDC0_D2                011: /<br>100: JTAG_CK1                101: /<br>110: /                        111: / |
| 19           | /          | /       | /                                                                                                                                                                            |
| 18:16        | R/W        | 0x0     | PF4 Select<br>000: Input                    001: Output<br>010: SDC0_D3                011: /<br>100: UART0_RX                101: /                                         |

|       |     |     |                                                                      |                                           |
|-------|-----|-----|----------------------------------------------------------------------|-------------------------------------------|
|       |     |     | 110: /                                                               | 111: /                                    |
| 15    | /   | /   | /                                                                    |                                           |
|       |     |     | PF3 Select<br>000: Input<br>010: SDC0_CMD<br>100: JTAG_DO1<br>110: / | 001: Output<br>011: /<br>101: /<br>111: / |
| 14:12 | R/W | 0x4 |                                                                      |                                           |
| 11    | /   | /   | /                                                                    |                                           |
|       |     |     | PF2 Select<br>000: Input<br>010: SDC0_CLK<br>100: UART0_TX<br>110: / | 001: Output<br>011: /<br>101: /<br>111: / |
| 10:8  | R/W | 0   |                                                                      |                                           |
| 7     | /   | /   | /                                                                    |                                           |
|       |     |     | PF1 Select<br>000: Input<br>010: SDC0_D0<br>100: JTAG_DI1<br>110: /  | 001: Output<br>011: /<br>101: /<br>111: / |
| 6:4   | R/W | 0x4 |                                                                      |                                           |
| 3     | /   | /   | /                                                                    |                                           |
|       |     |     | PF0 Select<br>000: Input<br>010: SDC0_D1<br>100: /<br>110: /         | 001: Output<br>011: /<br>101: /<br>111: / |
| 2:0   | R/W | 0x4 |                                                                      |                                           |

#### 40.4.47. PF Configure Register 1

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xB8 |            |         | Register Name: PF_CFG1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.48. PF Configure Register 2

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xBC |            |         | Register Name: PF_CFG2<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.49. PF Configure Register 3

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xC0 |            |         | Register Name: PF_CFG3<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |

|      |   |   |   |
|------|---|---|---|
| 31:0 | / | / | / |
|------|---|---|---|

#### 40.4.50. PF Data Register

|              |            |         |                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xC4 |            |         | Register Name: PF_DAT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                    |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                            |
| 31:28        | /          | /       | /                                                                                                                                                                                                                                                                                                      |
| 27:0         | R/W        | 0       | 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. |

#### 40.4.51. PF Multi-Driving Register 0

|                      |            |         |                                                                                                                                  |
|----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xC8         |            |         | Register Name: PF_DRV0<br>Default Value: 0x0000_0155                                                                             |
| Bit                  | Read/Write | Default | Description                                                                                                                      |
| 31:12                | /          | /       | /                                                                                                                                |
| [2i+1:2i]<br>(i=0~5) | R/W        | 0x1     | PF[n] Multi-Driving Select (n = 0~5)<br>00: Level 0                    01: Level 1<br>10: Level 2                    11: Level 3 |

#### 40.4.52. PF Multi-Driving Register 1

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xCC |            |         | Register Name: PF_DRV1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.53. PF Pull Register 0

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0xD0 |            |         | Register Name: PF_PULL0<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                           |
| 31:12        | /          | /       | /                                                     |

  

|                      |     |     |                                                                                                                                 |
|----------------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------|
| [2i+1:2i]<br>(i=0~5) | R/W | 0x0 | PF[n] Pull-up/down Select (n = 0~5)<br>00: Pull-up/down disable    01: Pull-up<br>10: Pull-down                    11: Reserved |
|----------------------|-----|-----|---------------------------------------------------------------------------------------------------------------------------------|

#### 40.4.54. PF Pull Register 1

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0xD4 |            |         | Register Name: PF_PULL1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                           |
| 31:0         | /          | /       | /                                                     |

#### 40.4.55. PG Configure Register 0

| Offset: 0xD8 |            |         | Register Name: PG_CFG0<br>Default Value: 0x0000_0000                                                                          |
|--------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                                                                                   |
| 31           | /          | /       | /                                                                                                                             |
| 30:28        | R/W        | 0       | PG7 Select<br>000: Input<br>010: SDC1_D2<br>100: /<br>110: EINT7<br>001: Output<br>011: /<br>101: UART2_TX<br>111: /          |
| 27           | /          | /       | /                                                                                                                             |
| 26:24        | R/W        | 0       | PG6 Select<br>000: Input<br>010: SDC1_D1<br>100: UART1_RTS<br>110: EINT6<br>001: Output<br>011: /<br>101: UART2_RTS<br>111: / |
| 23           | /          | /       | /                                                                                                                             |
| 22:20        | R/W        | 0       | PG5 Select<br>000: Input<br>010: SDC1_D0<br>100: UART1_CTS<br>110: EINT5<br>001: Output<br>011: /<br>101: /<br>111: /         |
| 19           | /          | /       | /                                                                                                                             |
| 18:16        | R/W        | 0       | PG4 Select<br>000: Input<br>010: SDC1_CLK<br>100: UART1_RX<br>110: EINT4<br>001: Output<br>011: /<br>101: /<br>111: /         |
| 15           | /          | /       | /                                                                                                                             |
| 14:12        | R/W        | 0       | PG3 Select<br>000: Input<br>010: SDC1_CMD<br>100: UART1_TX<br>110: EINT3<br>001: Output<br>011: /<br>101: /<br>111: /         |
| 11           | /          | /       | /                                                                                                                             |
| 10:8         | R/W        | 0       | PG2 Select<br>000: Input<br>010: GPS_MAG<br>100: /<br>110: EINT2<br>001: Reserved<br>011: /<br>101: /<br>111: /               |
| 7            | /          | /       | /                                                                                                                             |
| 6:4          | R/W        | 0       | PG1 Select                                                                                                                    |

|     |     |   |                                                                 |                                             |
|-----|-----|---|-----------------------------------------------------------------|---------------------------------------------|
|     |     |   | 000: Input<br>010:GPS_SIG<br>100: /<br>110: EINT1               | 001: Reserved<br>011: /<br>101: /<br>111: / |
| 3   | /   | / | /                                                               |                                             |
| 2:0 | R/W | 0 | PG0 Select<br>000: Input<br>010:GPS_CLK<br>100: /<br>110: EINT0 | 001: Reserved<br>011: /<br>101: /<br>111: / |

#### 40.4.56. PG Configure Register 1

| Offset: 0xDC |            |         | Register Name: PG_CFG1<br>Default Value: 0x0000_0000                |                                                   |
|--------------|------------|---------|---------------------------------------------------------------------|---------------------------------------------------|
| Bit          | Read/Write | Default | Description                                                         |                                                   |
| 31:24        | /          | /       | /                                                                   |                                                   |
| 23           | /          | /       | /                                                                   |                                                   |
| 22:20        | R/W        | 0       | PG13 Select<br>000: Input<br>010:SPI1_CS1<br>100: /<br>110: EINT13  | 001: Output<br>011: /<br>101: UART2_CTS<br>111: / |
| 19           | /          | /       | /                                                                   |                                                   |
| 18:16        | R/W        | 0       | PG12 Select<br>000: Input<br>010:SPI1_MISO<br>100: /<br>110: EINT12 | 001: Output<br>011: UART3_RTS<br>101: /<br>111: / |
| 15           | /          | /       | /                                                                   |                                                   |
| 14:12        | R/W        | 0       | PG11 Select<br>000: Input<br>010:SPI1_MOSI<br>100: /<br>110: EINT11 | 001: Output<br>011: UART3_CTS<br>101: /<br>111: / |
| 11           | /          | /       | /                                                                   |                                                   |
| 10:8         | R/W        | 0       | PG10 Select<br>000: Input<br>010:SPI1_CLK<br>100: /<br>110: EINT10  | 001: Output<br>011: UART3_RX<br>101: /<br>111: /  |
| 7            | /          | /       | /                                                                   |                                                   |
| 6:4          | R/W        | 0       | PG9 Select<br>000: Input                                            | 001: Output                                       |

|     |     |   |                                                                  |                                                  |
|-----|-----|---|------------------------------------------------------------------|--------------------------------------------------|
|     |     |   | 010:SPI1_CS0<br>100: /<br>110: EINT9                             | 011: UART3_TX<br>101: /<br>111: /                |
| 3   | /   | / | /                                                                |                                                  |
| 2:0 | R/W | 0 | PG8 Select<br>000: Input<br>010: SDC1_D3<br>100: /<br>110: EINT8 | 001: Output<br>011: /<br>101: UART2_RX<br>111: / |

#### 40.4.57. PG Configure Register 2

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xE0 |            |         | Register Name: PG_CFG2<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.58. PG Configure Register 3

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xE4 |            |         | Register Name: PG_CFG3<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### 40.4.59. PG Data Register

|              |            |         |                                                                                                                                                                                                                                                                                                        |
|--------------|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xE8 |            |         | Register Name: PG_DAT<br>Default Value: 0x0000_0000                                                                                                                                                                                                                                                    |
| Bit          | Read/Write | Default | Description                                                                                                                                                                                                                                                                                            |
| 31:28        | /          | /       | /                                                                                                                                                                                                                                                                                                      |
| 27:0         | R/W        | 0       | 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. |

#### 40.4.60. PG Multi-Driving Register 0

|                       |            |         |                                                                                                                               |
|-----------------------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0xEC          |            |         | Register Name: PG_DRV0<br>Default Value: 0x0555_5555                                                                          |
| Bit                   | Read/Write | Default | Description                                                                                                                   |
| 31:28                 | /          | /       | /                                                                                                                             |
| [2i+1:2i]<br>(i=0~13) | R/W        | 0x1     | PG[n] Multi-Driving Select (n = 0~13)<br>00: Level 0                  01: Level 1<br>10: Level 2                  11: Level 3 |

#### **40.4.61. PG Multi-Driving Register 1**

|              |            |         |                                                      |
|--------------|------------|---------|------------------------------------------------------|
| Offset: 0xF0 |            |         | Register Name: PG_DRV1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                          |
| 31:0         | /          | /       | /                                                    |

#### **40.4.62. PG Pull Register 0**

|                       |            |         |                                                                                                            |
|-----------------------|------------|---------|------------------------------------------------------------------------------------------------------------|
| Offset: 0xF4          |            |         | Register Name: PG_PULL0<br>Default Value: 0x0000_0000                                                      |
| Bit                   | Read/Write | Default | Description                                                                                                |
| 31:28                 | /          | /       | /                                                                                                          |
| [2i+1:2i]<br>(i=0~13) | R/W        | 0x0     | PG[n] Pull-up/down Select (n = 0~13)<br>00: Pull-up/down disable 01: Pull-up<br>10: Pull-down 11: Reserved |

#### **40.4.63. PG Pull Register 1**

|              |            |         |                                                       |
|--------------|------------|---------|-------------------------------------------------------|
| Offset: 0xF8 |            |         | Register Name: PG_PULL1<br>Default Value: 0x0000_0000 |
| Bit          | Read/Write | Default | Description                                           |
| 31:0         | /          | /       | /                                                     |

#### **40.4.64. PIO Interrupt Configure Register 0**

|                      |            |         |                                                                                                                                                                            |
|----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Offset: 0x200        |            |         | Register Name: PIO_INT_CFG0<br>Default Value: 0x0000_0000                                                                                                                  |
| Bit                  | Read/Write | Default | Description                                                                                                                                                                |
| [4i+3:4i]<br>(i=0~7) | R/W        | 0       | External INTn Mode (n = 0~7)<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 |

#### **40.4.65. PIO Interrupt Configure Register 1**

|                      |            |         |                                                                                                                |
|----------------------|------------|---------|----------------------------------------------------------------------------------------------------------------|
| Offset: 0x204        |            |         | Register Name: PIO_INT_CFG1<br>Default Value: 0x0000_0000                                                      |
| Bit                  | Read/Write | Default | Description                                                                                                    |
| [4i+3:4i]<br>(i=0~7) | R/W        | 0       | External INTn Mode (n = 8~15)<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level |

|  |  |  |                                                           |
|--|--|--|-----------------------------------------------------------|
|  |  |  | 0x4: Double Edge (Positive/ Negative)<br>Others: Reserved |
|--|--|--|-----------------------------------------------------------|

#### 40.4.66. PIO Interrupt Configure Register 2

| Offset: 0x208        |            |         | Register Name: PIO_INT_CFG2<br>Default Value: 0x0000_0000                                                                                                                    |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                                                                  |
| [4i+3:4i]<br>(i=0~7) | R/W        | 0       | External INTn Mode (n = 16~23)<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 |

#### 40.4.67. PIO Interrupt Configure Register 3

| Offset: 0x20C        |            |         | Register Name: PIO_INT_CFG3<br>Default Value: 0x0000_0000                                                                                                                    |
|----------------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                  | Read/Write | Default | Description                                                                                                                                                                  |
| [4i+3:4i]<br>(i=0~7) | R/W        | 0       | External INTn Mode (n = 24~31)<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 |

#### 40.4.68. PIO Interrupt Control Register

| Offset: 0x210   |            |         | Register Name: PIO_INT_CTL<br>Default Value: 0x0000_0000   |
|-----------------|------------|---------|------------------------------------------------------------|
| Bit             | Read/Write | Default | Description                                                |
| [n]<br>(n=0~31) | R/W        | 0       | External INTn Enable (n = 0~31)<br>0: Disable<br>1: Enable |

#### 40.4.69. PIO Interrupt Status Register

| Offset: 0x214   |            |         | Register Name: PIO_INT_STATUS<br>Default Value: 0x0000_0000                                       |
|-----------------|------------|---------|---------------------------------------------------------------------------------------------------|
| Bit             | Read/Write | Default | Description                                                                                       |
| [n]<br>(n=0~31) | R/W        | 0       | External INTn Pending Bit (n = 0~31)<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 40.4.70. PIO Interrupt Debounce Register

| Offset: 0x218 |            |         | Register Name: PIO_INT_DEB<br>Default Value: 0x0000_0000                        |
|---------------|------------|---------|---------------------------------------------------------------------------------|
| Bit           | Read/Write | Default | Description                                                                     |
| 31:7          | /          | /       | /                                                                               |
| 6:4           | R/W        | 0       | Debounce Clock Pre-scale n<br>The selected clock source is prescaled by $2^n$ . |
| 3:1           | /          | /       | /                                                                               |
| 0             | R/W        | 0       | PIO Interrupt Clock Select<br>0: 32KHz<br>1: 24MHz                              |

## 41. Declaration

This A10s user manual is the original work and copyrighted property of Allwinner Technology ("Allwinner"). Reproduction in whole or in part must obtain the written approval of Allwinner and give clear acknowledgement to the copyright owner.

The information furnished by Allwinner is believed to be accurate and reliable. Allwinner reserves the right to make changes in circuit design and/or specifications at any time without notice. Allwinner does not assume any responsibility and liability for its use. Nor for any infringements of patents or other rights of the third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Allwinner. This user manual neither states nor implies warranty of any kind, including fitness for any particular application.